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COMPUTER WITH TWO OPERATING SYSTEMS 



BACKGROUND 

This application is a continuation-in-part of International Application serial no. 

5 PCT/USOO/02239, filed January 28, 2000, which is a continuation-in-part of U.S. provisional 
application serial no. 60/176,610, filed January 18, 2000, which is a continuation-in-part of U.S. 
application serial no. 09/385,394, filed August 30, 1999, which is a continuation-in-part (C-I-P) 
of application serial no. 09/322,443, filed May 28, 1999, which is a continuation-in-part (C-I-P) 
of application serial no. 09/239,194, filed January 28, 1999, which are incorporated herein by 

10 reference. 

The invention relates to implementation of a computer central processor. 
Each instruction for execution by a computer is represented as a binary number stored in 
the computer's memory. Each different architecture of computer represents instructions 
differently. For instance, when a given instruction, a given binary number, is executed by an 

15 IBM System/360 computer, an IBM System/38, an IBM AS/400, an IBM PC, and an IBM 

PowerPC, the five computers will typically perform five completely different operations, even 
though all five are manufactured by the same company. This correspondence between the binary 
representation of a computer's instructions and the actions taken by the computer in response is 
called the Instruction Set Architecture (ISA). 

20 A program coded in the binary ISA for a particular computer family is often called 

simply "a binary." Commercial software is typically distributed in binary form. The 
incompatibility noted in the previous paragraph means that programs distributed in binary form 
for one architecture generally do not run on computers of another. Accordingly, computer users 
are extremely reluctant to change from one architecture to another, and computer manufacturers 

25 are narrowly constrained in modifying their computer architectures. 

A computer most naturally executes programs coded in its native ISA, the ISA of the 
architectural family for which the computer is a member. Several methods are known for 
executing binaries originally coded for computers of another, non-native, ISA. In hardware 
emulation, the computer has hardware specifically directed to executing the non-native 

30 instructions. Emulation is typically controlled by a mode bit, an electronic switch: when a non- 
native binary is to be executed, a special instruction in the emulating computer sets the mode bit 
and transfers control to the non-native binary. When the non-native program exits, the mode bit 
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is reset to specify that subsequent instructions are to be interpreted by the native ISA. Typically, 
in an emulator, native and non-native instructions are stored in different address spaces. A 
second alternative uses a simulator (also sometimes knovra as an "interpreter"), a program 
running on the computer that models a computer of the non-native architecture. A simulator 
5 sequentially fetches instructions of the non-native binary, determines the meaning of each 
instruction in turn, and simulates its effect in a softv^are model of the non-native computer. 
Again, a simulator typically stores native and non-native instructions in distinct address spaces. 
(The terms "emulation" and "simulation" are not as uniformly applied throughout the industry as 
might be suggested by the definitions implied here.) In a third alternative, binary translation, a 

1 0 translator program takes the non-native binary (either a v^hole program or a program fragment) 
as input, and processes it to produce as output a corresponding binary in the native instruction set 
(a "native binary") that runs directly on the computer. 

Typically, an emulator is found in a newer computer for emulation of an older computer 
architecture from the same manufacturer, as a transition aid to customers. Simulators are 

15 provided for the same purpose, and also by independent software vendors for use by customers 
who simply want access to software that is only available in binary form for a machine that the 
customer does not own. By whatever technique, non-native execution is slower than native 
execution, and a non-native program has access to only a portion of the resources available to a 
native program, 

20 Known methods of profiling the behavior of a computer or of a computer program 

include the following. In one known profiling method, the address range occupied by a program 
is divided into a number of ranges, and a timer goes off from time to time. A software profile 
analyzer figures out the address at which the program was executing, and increments a counter 
corresponding to the range that embraces the address. After a time, the counters will indicate 

25 that some ranges are executed a great deal, and some are barely executed at all. In another 
known profiling method, counters are generated into the binary text of a program by the 
compiler. These compiler-generated counters may count the number of times a given region is 
executed, or may count the number of times a given execution point is passed or a given branch 
is taken. 

30 
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SUMMARY 

In general, in a first aspect, the invention features a computer with an instruction 
processor designed to execute instructions of first and second instruction sets, a memory for 
storage of a program, a table of entries corresponding to the pages, a switch, a transition handler, 

5 and a history record. The memory is divided into pages for management by a virtual memory 
manager. The program is coded in instructions of the first and second instruction sets and uses 
first and second data storage conventions. The switch is responsive to a first flag value stored in 
each table entry, and controls the instruction processor to interpret instructions under, alternately, 
the first or second instruction set as directed by the first flag value of the table entry 

10 corresponding to an instruction's memory page. The transition handler is designed to recognize 
when program execution has transferred fi*om a page of instructions using the first data storage 
convention to a page of instructions using the second data storage convention, as indicated by 
second flag values stored in table entries corresponding to the respective pages, and in response 
to the recognition, to adjust a data storage configuration of the computer firom the first storage 

15 convention to the second data storage convention. The history record is designed to provide to 
the transition handler a record of a classification of a recently-executed instruction. 

In a second aspect, the invention features a method, and a computer for performance of 
the method. Instruction data are fetched from first and second regions of a single address space 
of the memory of a computer. The instructions of the first and second regions are coded for 

20 execution by computer of first and second architectures or following first and second data 
storage conventions, respectively. The memory regions have associated first and second 
indicator elements, the indicator elements each having a value indicating the architecture or data 
storage convention under which instructions from the associated region are to be executed. 
When execution of the instruction data flows firom the first region to the second, the computer is 

25 adapted for execution in the second architecture or convention. 

In a third aspect, the invention features a method, and a computer for performance of the 
method. Instructions are stored in pages of a computer memory managed by a virtual memory 
manager. The instruction data of the pages are coded for execution by, respectively, computers 
of two different architectures and/or under two different execution conventions. In association 

30 with pages of the memory are stored corresponding indicator elements indicating the architecture 
or convention in which the instructions of the pages are to be executed. Instructions from the 
pages are executed in a common processor, the processor designed, responsive to the page 
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indicator elements, to execute instructions in the architecture or under the convention indicated 
by the indicator element corresponding to the instruction's page. 

In a fourth aspect, the invention features a microprocessor chip. An instruction unit of 
the chip is configured to fetch instructions from a memory managed by the virtual memory 
5 manager, and configured to execute instructions coded for first and second different computer 
architectures or coded to implement first and second different data storage conventions. The 
microprocessor chip is designed (a) to retrieve indicator elements stored in association v^ith 
respective pages of the memory, each indicator element indicating the architecture or convention 
in which the instructions of the page are to be executed, and (b) to recognize when instruction 
10 execution has flowed from a page of the first architecture or convention to a page of the second, 
as indicted by the respective associated indicator elements, and (c) to alter a processing mode of 
the instruction unit or a storage content of the memory to effect execution of instructions in 
accord with the indicator element associated with the page of the second architecture or 
convention. 

15 In a fifth aspect, the invention features a method, and a microprocessor capable of 

performing the method. A section of computer object code is executed twice, without 
modification of the code section between the two executions. The code section materializes a 
destination address into a register and is architecturally defined to directly transfer control 
indirectly through the register to the destination address. The two executions materialize two 

20 different destination addresses, and the code at the two destinations is coded in two different 
instruction sets. 

In a sixth aspect, the invention features a method and a computer for the performance of 
the method. Control-flow instructions of the computer's instruction set are classified into a 
plurality of classes. During execution of a program on the computer, as part of the execution of 

25 instructions of the instruction set, a record is updated to record the class of the classified control- 
flow instruction most recently executed. 

In a seventh aspect, the invention features a method and a computer for the performance 
of the method. A control-transfer instruction is executed that transfers control from a source 
execution context to a destination instruction for execution in a destination execution context. 

30 Before executing the destination instruction, the storage context of the computer is adjusted to 
reestablish under the destination execution context the logical context of the computer as 
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interpreted under the source execution context. The reconfiguring is determined, at least in part, 
by a classification of the control-transfer instruction. 

In general, in an eighth aspect, the invention features a method of operating a computer. 
Concurrent execution threads are scheduled by a pre-existing thread scheduler of a computer. 
5 Each thread has an associated context, the association between a thread and a set of computer 
resources of the context being maintained by the thread scheduler. Without modifying the thread 
scheduler, an association is maintained between one of the threads and an extended context of 
the thread through a context change induced by the thread scheduler, the extended context 
including resources of the computer beyond those resources whose association with the thread is 

1 0 maintained by the thread scheduler. 

In a ninth aspect, the invention features a method of operating a computer. An entry 
exception is established, to be raised on each entry to an operating system of a computer at a 
specified entry point or on a specified condition. A resumption exception is established, to be 
raised on each resumption from the operating system following on a specified entry. On 

15 detecting a specified entry to the operating system from an interrupted process of the computer, 
the entry exception is raised and serviced. The resumption exception is raised and serviced, and 
control is returned to the interrupted process. 

In a tenth aspect, the invention features a method of operating a computer. Without 
modifying an operating system of the computer, an entry handler is established for execution at a 

20 specified entry point or on a specified entry condition to the operating system. The entry handler 
is programmed to save a context of an interrupted thread and to modify the thread context before 
delivering the modified context to the operating system. Without modifying the operating 
system, an exit handler is established for execution on resumption from the operating system 
following an entry through the entry handler. The exit handler is programmed to restore the 

25 context saved by a corresponding execution of the entry handler. 

In an eleventh aspect, the invention features a method of operating a computer. During 
invocation of a service routine of a computer, a linkage return address passed, the return address 
being deliberately chosen so that an attempt to execute an instruction from the retum address on 
return from the service routine will cause an exception to program execution. On retum from the 

30 service routine, the chosen exception is raised. After servicing the exception, control is retumed 
to a caller of the service routine. 
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Particular embodiments of the invention may include one or more of the following 
features. The regions may be pages managed by a virtual memory manager. The indications 
may be stored in a virtual address translation entry, in a table whose entries are associated with 
corresponding virtual pages, in a table whose entries are associated with corresponding physical 

5 page frames, in entries of a translation look-aside buffer, or in lines of an instruction cache. The 
code at the first destination may receive floating-point arguments and return floating-point return 
values using a register-based calling convention, while the code at the second destination 
receives floating-point arguments using a memory-based stack calling convention, and returns 
floating-point values using a register indicated by a top-of-stack pointer. 

10 The two architectures may be two instruction set architectures, and the instruction 

execution hardware of the computer may be controlled to interpret the instructions according to 
the two instruction set architectures according to the indications. A mode of execution of the 
instructions may be changed without further intervention when execution flows from the first 
region to the second, or the mode may be changed by an exception handler when the computer 

1 5 takes an exception when execution flows from the first region to the second. One of the regions 
may store an off-the-shelf operating system binary coded in an instruction set non-native to the 
computer. 

The two conventions may be first and second calling conventions, and the computer may 
recognize when program execution has transferred from a region using the first calling 

20 convention to a region using the second calling convention, and in response to the recognition, 
the data storage configuration of the computer will be adjusted from the first calling convention 
to the second. One of the two calling conventions may be a register-based calling convention, 
and the other calling convention may be a memory stack-based calling convention. There may 
be a defined mapping between resources of the first architecture and resources of the second, the 

25 mapping assigning corresponding resources of the two architectures to a common physical 

resource of a computer when the resources serve analogous functions in the calling conventions 
of the two architectures. The configuration adjustment may include altering a bit representation 
of a datum from a first representation to a second representation, the alteration of representation 
being chosen to preserve the meaning of the datum across the change in execution convention. 

30 A rule for copying data from the first location to the second may be determined, at least in part, 
by a classification of the instruction that transferred execution to the second region, and/or by 
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examining a descriptor associated with the location of execution before the recognized execution 
transfer. 

A first class of instructions may include instructions to transfer control between 
subprograms associated with arguments passed according to a calling convention, and a second 

5 class of instructions may include branch instructions whose arguments, if any, are not passed 
according to the calling convention. One of the execution contexts may be a register-based 
calling convention, and the other execution context may be a memory stack-based calling 
convention. The rearrangement may reflect analogous execution contexts under the two data 
storage conventions, the rearranging process being determined, at least in part, by the instruction 

10 classification record. In some of the control-flow instructions, the classification may be encoded 
in an immediate field of instructions, the immediate field having no effect on the execution of the 
instruction in which it is encoded, except to update the class record. In some of the control-flow 
instructions, the classification may be statically determined by the opcode of the instructions. In 
some of the control-flow instructions, the classification may be dynamically determined with 

15 reference to a state of processor registers and/or general registers of the computer. In some of 
the control-flow instructions, the classification may be dynamically determined based on a 
ftiU/empty status of a register indicated by a top-of-stack pointer, the register holding a fimction 
result value. The rearranging may be performed by an exception handler, the handler being 
selected by an exception vector based at least in part on the source data storage convention, the 

20 destination data storage convention, and the instruction classification record. Instructions of the 
instruction set may be classified as members of a don't-care class, so that when an instruction of 
the don't-care class is executed, the record is left undisturbed to indicate the class of the 
classified instruction most recently executed. The destination instruction may be an entry point 
to an off-the-shelf binary for an operating system coded in an instruction set non-native to the 

25 computer. 

The operating system may be an operating system for a computer architecture other than 
the architecture native to the computer. The computer may additionally execute an operating 
system native to the computer, and each exception may be classified for handling by one of the 
two operating systems. A linkage return address for resumption of the thread may be modified 
30 to include information used to maintain the association. At least some of the modified registers 
may be overwritten by a timestamp. The entry exception handler may alter at least half of the 
data registers of the portion of a process context maintained in association with the process by 
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the operating system before delivering the process to the operating system, a validation stamp 
being redundantly stored in at least one of the registers, and wherein at least some of the 
modified registers are overwritten by a value indicating the storage location in which at least the 
portion of the thread context is saved before the modifying. The operating system and the 
5 interrupted thread may execute in different instruction set architectures of the computer. During 
servicing the entry exception, a portion of the context of the computer may be saved, and the 
context of an interrupted thread may be altered before delivering the interrupted thread and its 
corresponding context to the operating system. When the thread scheduler and the thread 
execute in different execution modes of the computer, the steps to maintain the association 

10 between the thread and the context may be automatically invoked on a transition from the thread 
execution mode to the thread scheduler execution mode. The thread context may be saved in a 
storage location allocated from a pool of storage locations managed by a queuing discipline in 
which empty storage locations in which a context is to be saved are allocated from the head of 
the queue, recently-emptied storage locations for reuse are enqueued at the head of the queue, 

15 and full storage locations to be saved are queued at the tail of the queue. A calling convention 
for the thread execution mode may require the setting of a register to a value that specifies 
actions to be taken to convert operands from one form to another to conform to the thread 
scheduler execution mode. Delivery of an interrupt may be deferred by a time sufficient to allow 
the thread to reach a checkpoint, or execution of the thread may be rolled back to a checkpoint, 

20 the checkpoints being points in the execution of the thread where the amount of extended 
context, being the resources of the thread beyond those whose resource association with the 
thread is maintained by the thread schedixler, is reduced. The linkage return address may be 
selected to point to a memory page having a memory attribute that raises the chosen exception on 
at attempt to execute an instruction from the page. The service routine may be an interrupt 

25 service routine of an operating system for a computer architecture other than the architecture 

native to the computer, the service routine may be invoked by an asynchronous interrupt, and the 
caller may be coded in the instruction set native to the architecture. 

In general, in a twelfth aspect, the invention features a method and a computer. A 
computer program executes in a logical address space of a computer, with an address translation 

30 circuit translating address references generated by the program from the program's logical 
address space to the computer's physical address space. Profile information is recorded that 
records physical memory addresses referenced during an execution interval of the program. 
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In general, in a thirteenth aspect, a program is executed on a computer, the program 
referring to memory by virtual address. Concurrently with the execution of the program, profile 
information is recorded describing memory references made by the program, the profile 
information recording physical addresses of the profiled memory references. 

5 In general, in a fourteenth aspect, the invention features a computer with an instruction 

pipeline, a memory access unit, an address translation circuit, and profile circuitry. The 
instruction pipeline and memory access unit are configured to execute instructions in a logical 
address space of a memory of the computer. The address translation circuit for translating 
address references is generated by the program from the program's logical address space to the 

10 computer's physical address space. The profile circuitry is cooperatively interconnected with the 
instruction pipeline and is configured to detect, without compiler assistance for execution 
profiling, occurrence of profileable events occurring in the instruction pipeline, and 
cooperatively interconnected with the memory access imit to record profile information 
describing physical memory addresses referenced during an execution interval of the program. 

1 5 Embodiments of the invention may include one or more of the following features. The 

recorded physical memory references may include addresses of binary instructions referenced by 
an instruction pointer, and at least one of the recorded instruction references may record the 
event of a sequential execution flow across a page boundary in the address space. The recorded 
execution flow across a page boundary may occur within a single instruction. The recorded 

20 execution flow across a page boundary may occur between two instructions that are sequentially 
adjacent in the logical address space. At least one of the recorded instruction references may be 
a divergence of control flow consequent to an external interrupt. At least one of the recorded 
instruction references may indicate the address of the last byte of an instruction executed by the 
computer during the profiled execution interval. The recorded profile information may record a 

25 processor mode that determines the meaning of binary instructions of the computer. The 
recorded profile information may record a data-dependent change to a full/empty mask for 
registers of the computer. The instruction pipeline may be configured to execute instructions of 
two instruction sets, a native instruction set providing access to substantially all of the resources 
of the computer, and a non-native instruction set providing access to a subset of the resources of 

30 the computer. The instruction pipeline and profile circuitry may be further configured to effect 
recording of profile information describing an interval of the execution of an operating system 
coded in the non-native instruction set. 
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In general, in a fifteenth aspect, the invention features a method. A program is executed 
on a computer. Profile information is recorded concerning the execution of the program, the 
profile information recording of the address of the last byte of at least one instruction executed 
by the computer during a profiled interval of the execution. 

In general, in a sixteenth aspect, the invention features a method. A program is executed 
on a computer, without the program having been compiled for profiled execution, the program 
being coded in an instruction set in which an interpretation of an instruction depends on a 
processor mode not expressed in the binary representation of the instruction. Profile information 
is recorded describing an interval of the program's execution and processor mode during the 
profiled interval of tiie program, the profile information being efficiently tailored to annotate the 
profiled binary code with sufficient processor mode information to resolve mode-dependency in 
the binary coding. 

In general, in an seventeenth aspect, the invention features a computer with an instruction 
pipeline and profile circuitry. The instiuction pipeline is configured to execute instructions of 
the computer. The profile circuitry is configured to detect and record, without compiler 
assistance for execution profiling, profile information describing a sequence of events occurring 
in the instruction pipeline, the sequence including every event occurring during a profiled 
execution interval tiiat matches time-independent selection criteria of events to be profiled, the 
recording continuing until a predetermined stop condition is reached, and is configured to detect 
the occurrence of a predetermined condition to commence the profiled execution interval after a 
non-profiled interval of execution. 

In general, in a eighteenth aspect, tiie invention features a method and a computer with 
circuitry configured for performance of die method. During a profiled interval of an execution of 
a program on a computer, profile information is recorded describing the execution, without die 
program having been compiled for profiled execution, the program being coded in an instruction 
set in which an interpretation of an instruction depends on a processor mode not expressed in the 
binary representation of the instruction, the recorded profile information describing at least all 
events occurring during the profiled execution interval of the two classes: (1) a divergence of 
execution from sequential execution; and (2) a processor mode change that is not inferable from 
the opcode of the instruction tiiat induces the processor mode change taken togetiier with a 
processor mode before the mode change instruction. The profile information furtiier identifies 
each distinct physical page of instruction text executed during the execution interval. 
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Embodiments of the invention may include one or more of the following features. The 
profiled execution interval is commenced at the expiration of a timer, the recorded profile 
describing a sequence of events including every event that matches time-independent selection 
criteria of events to be profiled, the recording continuing until a predetermined stop condition is 

5 reached. A profile entry is recorded for later analysis noting the source and destination of a 
control flow event in which control flow of the program execution diverges from sequential 
execution. The recorded profile information is efficiently tailored to identify all bytes of object 
code executed during the profiled execution interval, without reference to the binary code of the 
program. A profile entry describing a single profileable event explicitly describes a page offset 

10 of the location of the event, and inherits a page number of the location of the event from the 
immediately preceding profile entry. Profile information records a sequence of events of the 
program, the sequence including every event during the profiled execution interval that matches 
time-independent criteria of profileable events to be profiled. The recorded profile information 
indicates ranges of instruction binary text executed by the computer during a profiled interval of 

1 5 the execution, the ranges of executed text being recorded as low and high boundaries of the 

respective ranges. The recorded high boundaries record the last byte, or the first byte of the last 
instruction, of the range. The captured profile information comprises subunits of two kinds, a 
first subunit kind describing an instruction interpretation mode at an instruction boundary, and a 
second subunit kind describing a transition between processor modes. During a non-profiled 

20 interval of the program execution, no profile information is recorded in response to the 

occurrence of profileable events matching predefined selection criteria for profileable events. 
The profile circuitry is designed to record a timestamp describing a time of the recorded events. 
The profile circuitry is designed to record an event code describing the class of each profileable 
event recorded. A number of bits used to record the event code is less than log2 of the number of 

25 distinguished event classes. 

In general, in a nineteenth aspect, the invention features a method. While executing a 
program on a computer, the occurrence of profileable events occurring in the instruction pipeline 
is detected, and the instruction pipeline is directed to record profile information describing the 
profileable events essentially concurrently with the occurrence of the profileable events, the 

30 detecting and recording occurring under control of hardware of the computer without software 
intervention. 
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In general, in a twentieth aspect, the invention features a computer that includes an 
instruction pipeline and profile circuitry. The instruction pipeline includes an arithmetic unit and 
is configured to execute instructions received fi-om a memory of the computer and the profile 
circuitry. The profile circuitry is common hardware control with the instruction pipeline. The 
5 profile circuitry and instruction pipeline are cooperatively interconnected to detect the 
occurrence of profileable events occurring in the instruction pipeline, the profile circuitry 
operable without software intervention to effect recording of profile information describing the 
profileable events essentially concunently with the occurrence of the profileable events. 

In general, in a twenty-first aspect, the invention features first and second CPU's. The 
10 first CPU is configured to execute a program and generate profile data describing the execution 
of the program. The second CPU is configured to analyze the generated profile data, while the 
execution and profile data generation continue on the first CPU, and to control the execution of 
the program on the first CPU based at least in part on the analysis of the collected profile data. 

In general, in a twenty-second aspect, the invention features a method. While executing a 
1 5 program on a computer, the computer using registers of a general register file for storage of 
instruction results, the occurrence of profileable events occurring in the instruction pipeline is 
detected. Profile information is recorded describing the profileable events into the general 
register file as the profileable events occur, v^thout first capturing the information into a main 
memory of the computer. 
20 In general, in a twenty-third aspect, the invention features a computer that includes a 

general register file of registers, an instruction pipeline and profile circuitry. The instruction 
pipeline includes an arithmetic imit and is configured to execute instructions fetched from a 
memory cache of the computer, and is in data communication with the registers for the general 
register file for storage of instruction results. The profile circuitry is operatively interconnected 
25 with the instruction pipeline and is configured to detect the occurrence of profileable events 

occurring in the instruction pipeline, and to capture information describing the profileable events 
into the general register file as the profileable events occur, without first capturing the 
information into a main memory of the computer. 

In general, in a twenty-fourth aspect, the invention features a computer. The instruction 
30 pipeline is configured to execute instructions of the computer. The profile circuitry is 

implemented in the computer hardware, and is configured to detect, without compiler assistance 
for execution profiling, the occurrence of profileable events occurring in the instruction pipeline, 
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and to direct recording of profile information describing the profileable events occurring during 
an execution interval of the program. Profile control bits implemented in the computer hardware 
have values that control a resolution of the operation of the profile circuitry. A binary translator 
is configured to translate programs coded in a first instruction set architecture into instructions of 
5 a second instruction set architecture. A profile analyzer is configured to analyze the recorded 
profile information, and to set the profile control bits to values to improve the operation of the 
binary translator. 

Embodiments of the invention may include one or more of the following features. At 
least a portion of the recording is performed by instructions speculatively introduced into the 

1 0 instruction pipeline. The profile circuitry is interconnected with the instruction pipeline to direct 
the recording by injection of an instruction into the pipeline, the instruction controlling the 
pipeline to cause the profileable event to be materialized in an architecturally-visible storage 
register of the computer. An instruction of the computer, having a primary effect on the 
execution the computer not related to profiling, has an immediate field for an event code 

1 5 encoding the nature of a profiled event and to be recorded in the profile information, the 

immediate field having no effect on computer execution other than to determine the event code 
of the profiled event. Instances of the instruction have an event code that leaves intact an event 
code previously determined by other event monitoring circuitry of the computer. The profiled 
information includes descriptions of events whose event codes were classified by instruction 

20 execution hardware, without any explicit immediate value being recorded in software. The 
instruction pipeline and profile circuitry are operatively interconnected to effect injection of 
multiple instructions into the instruction pipeline by the profile circuitry on the occurrence of a 
single profileable event. The instruction pipeline and profile circuitry are operatively 
interconnected to effect speculative injection of the instruction into the instruction pipeline by 

25 the profile circuitry. A register pointer of the computer indicates a general register into which to 
record the profile information, and an incrementer is configured to increment the value of the 
register pointer to indicate a next general register into which to record next profile information, 
the incrementing occurring without software intervention. A limit detector is operatively 
interconnected with the register pointer to detect when a range of registers available for 

30 collecting profile information is exhausted, and a store unit is operatively interconnected with the 
limit detector of effect storing the profile information fi^om the general registers to the main 
memory of tiie computer when exhaustion is detected. The profile circuitry comprises a plurality 
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of storage registers arranged in a plurality of pipeline stages, information recorded in a given 
pipeline stage being subject to modification as a corresponding machine instruction progresses 
through the instruction pipeline. When an instruction fetch of an instruction causes a miss in a 
translation look aside buffer (TLB), the fetch of the instruction triggering a profileable event, the 
5 TLB miss is serviced, and the corrected state of the TLB is reflected in the profile information 
recorded for the profileable instruction. The profile control bits include a timer interval value 
specifying a frequency at which the profile circuitry is to monitor the instruction pipeline for 
profileable events. The profile circuitry comprises a plurality of storage registers arranged in a 
plurality of pipeline stages, information recorded in a given pipeUne stage is subject to 
1 0 modification as a corresponding machine instruction progresses through the instruction pipeline. 

In general, in a tv^enty-fifth aspect, the invention features a computer with instruction 
pipeline circuitry designed to effect interpretation of computer instructions under two instruction 
set architectures alternately. Pipeline control circuitry is cooperatively designed with the 
instruction pipeline circuitry to initiate, without software intervention, when about to execute a 
1 5 program region coded in a lower-performance one of the instruction set architectures, a query 
whether a program region coded in a higher-performance one of the instruction set architectures 
exists, the higher-performance region being logically equivalent to the lower-performance 
program region. Circuitry and/or software is designed to transfer execution control to the higher- 
performance region, without a transfer-of-control instruction to the higher-performance region 
20 being coded in the lower-performance instruction set. 

In general, in a twenty-sixth aspect, the invention features a method and a computer for 
performance of the method. At least a selected portion of a computer program is translated from 
a first binary representation to a second binary representation. During execution of the first 
binary representation of the program on a computer, it is recognized that execution has entered 
25 the selected portion, the recognizing being initiated by basic instruction execution of the 

computer, with neither a query nor a transfer of control to the second binary representation being 
coded into the first binary representation. In response to the recognition, control is transferred to 
the translation in the second representation. 

In general, in a twenty-seventh aspect, the invention features a method and a computer 
30 for performance of the method. As part of executing an instruction on a computer, it is 

recognized that an alternate coding of the instruction exists, the recognizing being initiated 
without executing a transfer of control to the alternate coding or query instruction to trigger the 
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recognizing. When an alternate coding exists, the execution of the instraction is aborted, and 
control is transferred to the alternate coding. 

In general, in a twenty-eighth aspect, the invention features a method and a computer for 
performance of the method. During execution of a program on instruction pipeline circuitry of a 
5 computer, a determination is initiated of whether to transfer control from a first instruction 

stream in execution by the instruction pipeline circuitry to a second instruction stream, without a 
query or transfer of control to the second instruction stream being coded into the first instruction 
stream. Execution of the first instruction stream is established after execution of the second 
instruction stream, execution of the first instruction stream being reestablished at a point 
10 downstream from the point at which control was seized, in a context logically equivalent to that 
which would have prevailed had the code of the first instruction stream been allowed to proceed. 

In general, in a twenty-ninth aspect, the invention features a method and a computer for 
performance of the method. Execution of a computer program is initiated, using a first binary 
image of the program. During the execution of the first image, control is transferred to a second 
15 image coding the same program in a different instruction set. 

In general, in a thirtieth aspect, the invention features a method and a computer for 
performance of the method. As part of executing an instruction on a computer, a heuristic, 
approximately-correct recognition that an alternate coding of the instruction exists is evaluated, 
the process for recognizing being statistically triggered. If the alternate coding exists, execution 
20 of the instruction is aborted, and control is transferred to the alternate coding. 

In general, in a thirty-first aspect, the invention features a method and a computer for 
performance of the method. A microprocessor chip has instruction pipeline circuitry, lookup 
circuitry, a mask, and pipeline control circuitry. The lookup circuitry is designed to fetch an 
entry from a lookup structure as part of the basic instruction processing cycle of the 
25 microprocessor, each entry of the lookup structure being associated v^th a corresponding address 
range of a memory of the computer. The mask has a value set at least in part by a timer. The 
pipeline control circuitry is designed to control processing of instructions by the instruction 
pipeline circuitry as part of the basic instruction processing cycle of the microprocessor, 
depending, at least in part, on the value of the entry corresponding to the address range in which 
30 lies an instruction processed by the instruction pipeline circuitry, and the current value of the 
mask. 
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In general, in a thirty-second aspect, the invention features a method and a 
microprocessor chip for performance of the method. The microprocessor chip has instruction 
pipeUne circuitry; instruction classification circuitry responsive to execution of instructions 
executed by the instruction pipeline circuitry to classify the executed instructions into a small 
number of classes and record a classification code value; lookup circuitry designed to fetch an 
entry from a lookup structure as part of the basic instruction processing cycle of the 
microprocessor, each entry of the lookup structure being associated with a corresponding address 
range of a memory of the computer; and pipeline control circuitry designed to control processing 
of instructions by the instruction pipeline circuitry as part of the basic instruction processing 
cycle of the microprocessor, depending, at least in part, on the value of the entry corresponding 
to the address range in which the instruction address lies, and the recorded classification code. 

In general, in a thirty-third aspect, the invention features a method and a microprocessor 
chip for performance of the method. The microprocessor chip includes instruction pipeline 
circuitry; an on-chip table, each entry of the on-chip table corresponding to a respective class of 
event occurring the in the computer, and designed to hold an approximate evaluation of a portion 
of the computer machine state for control of the circuitry; and pipeline control circuitry 
cooperatively designed with the instruction pipeline circuitry to control processing of 
instructions by the instruction pipeline circuitry as part of the basic instruction processing cycle 
of the microprocessor, based on consultation of the on-chip table. 

In general, in a thirty-fourth aspect, the invention features a method and a microprocessor 
chip for performance of the method. The microprocessor chip includes instruction pipeline 
circuitry; an on-chip table, each entry of the on-chip table corresponding to a class of event 
occurring the in the computer and designed to control consultation of an off-chip table in a 
memory of the computer when an event of the class occurs; pipeline control circuitry 
cooperatively designed with the instruction pipeline circuitry to consult the on-chip table as part 
of the basic instruction processing cycle of the microprocessor, as the classified events occur; 
and control circuitry and/or software designed to cooperate with the instruction pipeline circuitry 
and pipeline control circuitry to affect a manipulation of data or transfer of control defined for 
the event in the instruction pipeline circuitry based on consultation of the off-chip table after a 
favorable value is obtained from the on-chip table. 

Embodiments of the invention may include one or more of the following features. The 
transfer of execution control to the higher-performance region may be effected by an 



Atty. Docket No. 30585/28 

NYDOCS04/ 285781 



16 



Express Mail Label EI465234796US 



architecturally-visible alteration of a program counter. The region about to be executed may be 
entered by a transfer of control instruction. The first image may be coded in an instruction set 
non-native to the computer, for hardware emulation in the computer. Instructions of the second 
binary representation may be coded in a different instruction set architecture than instructions of 

5 the first binary representation. The second image may have been generated from the first image 
by a binary translator. The binary translator may have optimized the second image for increased 
execution speed, while accepting some risk of execution differing from the execution of the non- 
native program on its native instruction set architecture. A decision on whether to transfer 
control from the first image to the second may be based on control variables of the computer. 

1 0 The classes of events may be memory references to corresponding respective address ranges of a 
memory of the computer. The address ranges may correspond to entries in an interrupt vector 
table. The recognition may be initiated by consulting a content-addressable memory addressed 
by a program counter address of the instruction to be executed. The content-addressable 
memory may be a translation lookaside buffer. The off-chip table may be organized as a side 

1 5 table to an address translation page table. The on-chip table may contain a condensed 

approximation of the off-chip table, loaded from the off-chip table. The lookup structure may be 
a bit vector. Bits of the entry corresponding to the address range in which the instruction address 
lies may be AND'ed with corresponding bits of a mask associated with the instruction pipeline 
circuitry. Error in the approximation of the on-chip table may be induced by a slight time lag 

20 relative to the portion of the computer's machine state whose evaluation is stored therein. The 
pipeline control circuitry may be designed to control processing of instructions by the instruction 
pipeline circuitry by evaluating the value of the entry corresponding to the address range in 
which the instruction address lies and the recorded classification code, and triggering a software 
evaluation of a content of the memory addressed by the microprocessor chip. The control of 

25 instruction processing may include branch destination processing. 

In general, in a thirty-fifth aspect, the invention features a method and a microprocessor 
chip for performance of the method. Instructions are executed on a computer, instruction 
pipeline circuitry of the computer having first and second modes for processing at least some of 
the instructions. Execution of two-mode instructions is attempted in the first mode for 

30 successive two-mode instructions while the first execution mode is successful. When an 

unsuccessful execution of a two-mode instruction under the first mode is detected, following 
two-mode instructions are executed in the second mode. 
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In general, in a thirty-sixth aspect, the invention features a method and a microprocessor 
chip for performance of the method. Computer instructions are executed in instruction pipeline 
circuitry having first and second modes for processing at least some instructions. On expiration 
of a timer, the instruction pipeline circuitry switches from the first mode to the second, the mode 
5 switch persisting for instructions subsequently executed on behalf of a program that was in 
execution immediately before the timer expiry. 

In general, in a thirty-seventh aspect, the invention features a method and a 
microprocessor chip for performance of the method. Events of a computer are assigned into 
event classes. As part of the basic execution cycle of a computer instruction pipeline, without 
10 software intervention, a record of responses to events of the class is maintained. As each 

classified event comes up for execution in the instruction pipeline circuitry, the record is queried 
to determine the response to the previous attempt of an event of the same class. The response is 
attempted if and only if the record indicates that the previous attempt succeeded. 

Embodiments of the invention may include one or more of the following features. The 
1 5 first and second modes may be alternative cache policies, or alternative modes for performing 
floating-point arithmetic. Unsuccessfiil execution may includes correct completion of an 
instruction at a high cost. The cost metric may be execution time. The cost of an instruction in 
the first mode may be only ascertainable after completion of the instruction. The instruction 
pipeline circuitry may be switched back from the second mode to the first, the switch persisting 
20 until the next timer expiry. All of the records may be periodically set to indicate that previous 
attempts of the corresponding events succeeded. 

In general, in a thirty-eighth aspect, the invention features a method and a microprocessor 
chip for performance of the method. As part of the basic instruction cycle of executing an 
instruction of a non-supervisor mode program executing on a computer, a table is consulted, the 
25 table being addressed by the address of instructions executed, for attributes of the instructions. 
An architecturally-visible data manipulation behavior or control transfer behavior of the 
instruction is controlled based on the contents of a table entry associated with the instruction. 

Embodiments of the invention may include one or more of the following features. The 
different instruction may be coded in an instruction set architecture (ISA) different than the ISA 
30 of the executed instruction. The control of architecturally- visible data manipulation behavior 
may include changing an instruction set architecture under which instructions are interpreted by 
the computer. Each entry of the table may correspond to a page managed by a virtual memory 
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manager, circuitry for locating a table entry being integrated with virtual memory address 
translation circuitry of the computer. An interrupt may be triggered on execution of an 
instruction of a process, synchronously based at least in part on a memory state of the computer 
and the address of the instruction, the architectural definition of the instruction not calling for an 
5 interrupt. Interrupt handler software may be provided to service the interrupt and to return 
control to an instruction flow of the process other than the instruction flow triggering the 
interrupt, the retumed-to instruction flow for carrying on non-error handling normal processing 
of the process. 

In general, in a thirty-ninth aspect, the invention features a method and a microprocessor 
10 chip for performance of the method. A microprocessor chip has instruction pipeline circuitry, 
address translation circuitry; and a lookup structure. The lookup structure has an entry 
associated with each corresponding address range translated by the address translation circuitry, 
the entry describing a likelihood of the existence of an ahemate coding of instructions located in 
the respective corresponding address range. 
15 Embodiments of the invention may include one or more of the following features. The 

entry may be an entry of a translation look-aside buffer. The alternate coding may be coded in 
an instruction set architecture (ISA) different than the ISA of the instruction located in the 
address range. 

In general, in a fortieth aspect, the invention features a method and a microprocessor chip 
20 for performance of the method. A microprocessor chip has instruction pipeline circuitry and 

interrupt circuitry. The interrupt circuitry is cooperatively designed with the instruction pipeline 
circuitry to trigger an interrupt on execution of an instruction of a process, synchronously based 
at least in part on a memory state of the computer and the address of the instruction, the 
architectural definition of the instruction not calling for an interrupt. 
25 Embodiments of the invention may include one or more of the following features. 

Interrupt handler software may be designed to service the interrupt and to return control to an 
instruction flow of the process other than the instruction flow triggering the interrupt, the 
retumed-to instruction flow for carrying on non-error handling normal processing of the process. 
The interrupt handler software may be programmed to change an instruction set architecture 
30 under which instructions are interpreted by the computer. The instruction text beginning at the 
retumed-to instmction may be logically equivalent to the instraction text beginning at the 
interrapted instraction. 
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In general, in a forty-first aspect, the invention features a method and a microprocessor 
chip for performance of the method. As part of executing a stream of instructions, a series of 
memory loads is issued from a computer CPU to a bus, some directed to well-behaved memory 
and some directed to non-well-behaved devices in I/O space. A storage of the computer records 

5 addresses of instructions of the stream that issued memory loads to the non-well-behaved 

memory, the storage form of the recording allowing determination of whether the memory load 
was to well-behaved memory or not- well-behaved memory without resolution of any memory 
address stored in the recording. 

In general, in a forty-second aspect, the invention features a method and a computer for 

10 performance of the method. A successful memory reference is issued from a computer CPU to a 
bus. A storage of the computer records whether a device accessed over the bus by the memory 
reference is well-behaved memory or not-well-behaved memory. Alternatively, the memory 
may store a record of a memory read instruction that references a device other than well-behaved 
memory. 

1 5 Embodiments of the invention may include one or more of the following features. The 

recording may be a portion of a profile primarily recording program control flow. The recording 
may be read by a binary translation program, wherein the binary translation program translates 
the memory load using more conservative assumptions when the recording indicates that the 
memory load is directed to non-well-behaved memory. References to I/O space may be recorded 

20 as being references to non-well-behaved memory. The recording may be slightly in error, the 
error being induced by a conservative estimate in determining when the memory reference 
accesses well-behaved memory. The form of the recording may allow determination of whether 
the memory reference was to well-behaved memory or not-well-behaved memory without 
resolution of any memory address stored in the recording. The form of the recording may 

25 indicates an address of an instruction that issued the memory reference. The memory reference 
may be a load. The profile monitoring circuitry may be interwoven with the computer CPU. A 
TLB (translation lookaside buffer) may be designed to hold a determination of whether memory 
mapped by entries of the TLB is well-behaved or non-well-behaved memory. The profile 
monitoring circuitry may generate the record into a general purpose register of the computer. 

30 The profile monitoring circuitry may be designed to induce a pipeline flush of the computer 
CPU, 
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In general, in a forty-third aspect, the invention features a method and computer circuitry 
for performance of the method. DMA (direct memory access) memory write transactions of a 
computer are monitored, and an indication of a memory location written by a DMA memory 
write transaction is recorded, by circuitry operating without being informed of the memory write 

5 transaction by the CPU beforehand. The indication is read by the CPU. 

In general, in a forty-fourth aspect, the invention features a method and computer for 
performance of the method. A first process of a computer generates a second representation in a 
computer memory of information stored in the memory in a first representation. Overwriting of 
the first representation by a DMA memory write transaction initiated by a second process is 

1 0 detected by the first process, without the second process informing the first process of the DMA 
memory write transaction, the detecting guaranteed to occur no later than the next access of the 
second representation following the DMA memory write transaction. 

In general, in a forty-fifth aspect, the invention features a method and computer for 
performance of the method. A computer's main memory is divided into pages for management 

15 by a virtual memory manager. The manager manages the pages using a table stored in the 
memory. Circuitry records indications of modification to pages of the main memory into a 
plurality of registers outside the address space of the main memory. The virtual memory 
management tables do not provide backing store for the modification indications stored in the 
registers. 

20 In general, in a forty-sixth aspect, the invention features a method and computer circuitry 

for performance of the method. Modifications to the contents of a main memory of a computer 
are monitored, and on detection of a modification, an approximation of the address of the 
modification is written into an address tag of one of a plurality of registers, and a fine indication 
of the address of the modification is written into a memory cell of a plurality of cells of the 

25 register. The fine indication of the address of the modification is provided to a CPU of the 
computer through a read request from the CPU, 

Embodiments of the invention may include one or more of the following features. The 
recorded indication may record only the memory location, and not the datxmi written to the 
location. Based at least in part by the value read by the CPU, a cached datum may be erased. 

30 Two DMA memory writes near each other in address and time may generate only a single record 
of a write. The recorded indication of a location in the main memory may indicate a physical 
address in the memory. A value of each bit of a bit vector may indicate whether a corresponding 
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region in the main memory has been recently modified. Matching circuitry may be provided to 
match an address of a memory modification to an address of a previously-stored indication of a 
previous nearby memory modification. The recorded indication of a location in the main 
memory may be initially recorded in an architecturally-visible location outside the main memory 

5 and outside a general register file of the computer. The recorded indication of a location in the 
main memory may be recorded, at least in part, based on a subdivision of the main memory into 
regions each consisting of a naturally-aligned block of pages of the memory. The DMA 
monitoring circuitry being designed to monitor transactions on I/O gatev^ay circuitry between the 
CPU and the DMA devices. The DMA monitoring circuitry may dismiss a content of the DMA 

10 monitoring circuitry as a side-effect of being read. The address of the modification stored in the 
address tag may be a physical memory address. The vector of memory cells may include a bit 
vector, a value of each bit of the bit vector designed to indicate whether a corresponding region 
in the main memory has been recently modified. The address tag may include a content- 
addressable memory. A one of the plurality of registers may be associated with an address range 

1 5 by v^iting an address into the address tag of the one register. Later, the one register may be 

associated with a different address range by writing a different address into the address tag of the 
one register. A value of each bit of a bit vector may indicate whether a corresponding region in 
the main memory has been recently modified. 

In general, in a forty-seventh aspect, the invention features a method and computer for 

20 performance of the method. As a program is executed in a computer, writes to a protected region 
of a main memory of the computer are detected, the reporting being performed by monitoring 
circuitry of the computer. On receiving the report of the detection, a data structure of content 
corresponding to the content of the protected region to which the write was detected is deleted 
from the memory. 

25 In general, in a forty-eighth aspect, the invention features a method and computer for 

performance of the method. Memory read references are generated in a CPU of a computer, the 
memory references referring to logical addresses. Circuitry and/or software evaluates whether 
main memory pages of the references are in a protected state. Pages that are unprotected are put 
into a protected state. 

30 In general, in a forty-ninth aspect, the invention features a method and computer for 

performance of the method. Memory references are generated by a CPU of a computer, the 
memory references referring to logical addresses. The translation of logical addresses into a 
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physical addresses evaluates whether the page of the reference is protected against the access. 
Pages that are protected have their protection modified, without modifying the contents of the 
page. 

Embodiments of the invention may include one or more of the following features. The 

5 monitoring and detection circuitry may be responsive to memory writes generated by store 
operations initiated by instructions executed by pipeline circuitry of the computer. The 
evaluation circuitry may be incorporated into address translation circuitry designed to translate 
logical addresses, generated as part of memory read accesses by a CPU of the computer, into 
physical addresses. The protection of memory regions may be recorded in a table of entries, 

10 each entry corresponding to a page of the main memory. The table entries may be organized in 
correspondence to physical pages of the main memory. The table entries may constitute a table 
in main memory distinct from a page table used by a virtual memory manager of the computer. 
The table of entries may be a translation lookaside buffer. A profiling or monitoring function of 
the computer may be enabled or disabled for regions of the memory of the computer, based on 

1 5 whether the respective regions are protected or unprotected. An arithmetic result or branch 
destination of an instruction may be controlled based on whether a region containing the 
instruction is protection or unprotected. The data structure may be formed by translating a 
computer program stored in the protected region in a first instruction set architecture into a 
second instruction set architecture. On receiving the report of the detection, an interrupt may be 

20 raised to invoke software, the invoked software affecting the contents of the memory without 
reference to the contents of the protected region. The memory read reference may be an 
instruction fetch. 

In general, in a fiftieth aspect, the invention features a method and computer for 
performance of the method. Memory references generated as part of executing a stream of 

25 instructions on a computer are evaluated to determined whether an individual memory reference 
of an instruction references a device having a valid memory address but that cannot be 
guaranteed to be well-behaved. 

In general, in a fifty-first aspect, the invention features a method and computer for 
performance of the method. While translating at least a segment of a binary representation of a 

30 program from a first instruction set architecture to a second representation in a second instruction 
set architecture, individual memory loads that are believed to be directed to well-behaved 
memory are distinguished from memory loads that are believed to be directed to non-well- 
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behaved memory device(s). While executing the second representation, a load is identified that 
was believed at translation time to be directed to v^ell-behaved memory but that at execution is 
found to be directed to non-well-behaved memory. The identified memory load is aborted. 
Based at least in part on the identifying, at least a portion of the translated segment of the 
program is re-executed in the first instruction set. 

In general, in a fifty-second aspect, the invention features a method and computer for 
performance of the method. A binary translator translates at least segment of a program from a 
first representation in a first instruction set architecture to a second representation in a second 
instruction set architecture, a sequence of side-effects in the second representation differing from 
a sequence of side-effects in the translated segment of the first representation. Instruction 
execution circuitry and/or software identifies cases during execution of the second representation 
in which the difference in sequence of side-effects may have a material effect on the execution of 
the program. A program state, equivalent to a state that would have occurred in the execution of 
the first representation, is established. Execution resumes from the established state in an 
execution mode that reflects the side-effect sequence of the first representation. 

Embodiments of the invention may include one or more of the following features. If the 
reference cannot be guaranteed to be well-behaved, the instruction may be re-executed in an 
alternative execution mode, or program state may be restored to a prior state. The second 
representation may be annotated with an indication of the distinction between individual memory 
loads that are believed to be directed to well-behaved memory from memory loads that are 
believed to be directed to non-well-behaved memory. The device having a valid memory 
address may have an address in an I/O space of the computer. Code in a preamble of a program 
unit embracing the memory-reference instruction may establish a state of the instruction 
execution circuitry, the instruction execution circuitry designed to raise an exception based on an 
evaluation of both the state and the evaluation of the reference to the device. An annotation 
embedded in the instruction may be evaluated to determine whether the reference to the non- 
well-behaved device is to raise an exception. An evaluation of whether the instruction of the 
individual side-effect is to raise an exception may occur in circuitry embedded in an address 
translation circuitry of the computer. An exception may be raised, based on an evaluation of 
both a segment descriptor and the evaluation of the side-effect. An annotation encoded in a 
segment descriptor may be evaluated to determine whether the reference to the non-well-behaved 
device is to raise an exception. The segment descriptor may be formed by copying another 
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segment descriptor, and altering the annotation. The formed segment descriptor may copy a 
variable indicating an assumed sensitivity of the translation to alteration of the sequence of side- 
effects. The difference of ordering of side-effects may include a reordering of two side-effects 
relative to each other, an elimination of a side-effect by the translating, or combining two side- 
effects in the binary translator. The restoring step may be initiated when an exception occurs in 
the object program. Execution may resume from the restored state, the resumed execution 
executing a precise side-effect emulation of the reference implementation. A descriptor 
generated during the translation may be used to restore state to the pre-exception reference state. 

In general, in a fifty-third aspect, the invention features a method and computer for 
performance of the method. A first interpreter executes a program coded in an instruction set, 
the first interpreter being less than fully correct. A second, fully-correct interpreter, primarily in 
hardware, executes instructions of the instruction set. A monitor detects any deviation from 
fully-correct interpretation by the first interpreter, before any side-effect of the incorrect 
interpretation is irreversibly committed. When the monitor detects the deviation, execution is 
rolled back by at least a full instruction to a safe point in the program, and execution is re- 
initiated in the second interpreter. 

In general, in a fifty-forth aspect, the invention features a method and computer for 
performance of the method. A binary translator translates a source program into an object 
program, the translated object program having a different execution behavior than the source 
program. An interrupt handler responds to an interrupt occurring during execution of the object 
program by establishing a state of the program corresponding to a state that would have occurred 
during an execution of the source program, and from which execution can continue, and initiates 
execution of the source program from the established state. 

Embodiments of the invention may include one or more of the following features. The 
first interpreter may include a software emulator, and/or a software binary translator. The second 
interpreter may interpret instructions in an instruction set not native to the computer. The 
software binary translator may operate concurrently with execution of the program to translate a 
segment less than the whole of the program. Continuing execution may include rolling back 
execution of the first interpreter by at least two full instructions. Continuing execution may 
include rolling back execution of the first interpreter from a state in which a number of distinct 
suboperations of several instructions have been intermixed by the first interpreter. Continuing 
execution may include rolling back execution to a checkpoint, or allowing execution to progress 
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forward to a checkpoint in the first interpreter. The detected deviation from fully-correct 
interpretation may includes detection of the invalidity of a program transformation introduced by 
the binary translator, or detection of a synchronous execution exception. 

In general, in a fifty-fifth aspect, the invention features a method and computer for 
performance of the method. Instructions of a user-state program coded in a RISC instruction set 
are decoded in a hardware instruction decoder. Instructions of a user-state program coded in a 
CISC instruction set are decoded in a CISC instruction decoder. Instructions decoded by the 
CISC decoder and RISC decoder are executed in a common execution pipeline. 

In general, in a fifty-sixth aspect, the invention features a method and computer for 
performance of the method. A program is executed in a computer having a hardware instruction 
decoder implementing less than an entire architectural definition of an instruction set. A 
remainder of the instruction set is implemented in a software emulator. 

In general, in a fifty-seventh aspect, the invention features a method and computer for 
performance of die method. A program coded in an instruction set is executed on a computer 
having a file of general registers. The instruction set provides accessibility to only a subset of 
the general register file. Intermediate results of instructions of tiie instruction set are stored in 
registers of the general register file that are inaccessible in the instioiction set. 

Preferred embodiments of the invention may include one or more of the following 
features. An exception handler for initiation by an exception occurring at an intermediate point 
during execution of a CISC instruction set may be coded in the RISC instruction set, which may 
have accessibility to the registers inaccessible in the CISC instruction set. Any saving of the 
intermediate results of the CISC instruction as part of a save of machine state may use 
mechanisms used for saving general registers. The CISC instruction decoder may generate 
instructions in the RISC instiniction set for execution by the instruction execution pipeline. A 
last of the RISC instructions generated for each CISC instruction may carry a marker indicating 
that it is the last RISC instruction for the CISC instruction. A plurality of the RISC instructions 
generated for a single CISC instruction may carry a marker indicating that the computer may 
accept an exception at the marked RISC instiaiction. The CISC instruction decoder may be 
designed to generate multiple RISC instructions for parallel execution. Multiple exceptions may 
be raised by the RISC instructions generated for a single CISC instiiiction, and collected for 
presentation to a CISC processing environment. The CISC instruction decoder and instruction 
execution pipeline may be designed, with at most limited exceptions, to independentiy complete 
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the RISC instructions generated for CISC instructions once the CISC instructions are issued to 
the instruction execution pipeline. The instruction execution pipeline, with at most limited 
exceptions, may be designed to process the RISC instructions independently of whether the 
RISC instructions were decoded by the RISC instruction decoder or generated by the CISC 

5 instruction decoder. The instruction execution pipeline, with at most limited exceptions, may be 
designed to process the RISC instructions independently a point within a recipe of a CISC 
instruction at which the RISC instruction was generated. The RISC and CISC instruction 
decoders may be designed to emit RISC instructions to the instruction execution pipeline in a 
unified format with identical operational codings, differing at most by a source designator. The 

10 RISC instruction set may have a condition-code based compare and branch repertoire. The RISC 
instruction set may include designators into a unified register file designed to contain integer and 
floating-point data, and the CISC instruction set may include designators into distinct integer and 
floating-point register files. Intermediate results of multiple-side-effect instructions in the CISC 
instruction set may be held in temporary registers of the computer that are not explicitly 

1 5 designated in the representations of the CISC instructions themselves. Instructions of the RISC 
instruction set may include designators into a register file, the RISC register designators 
including designators to the temporary registers used in the CISC instruction set, A memory 
management unit may manage the instructions of the RISC and CISC instruction sets between a 
main memory of the computer and one or more cache levels. Some instructions of the CISC 

20 program may be executed entirely in the software emulator, and some instructions may be 
partially implemented in the hardware instruction decoder and partially implemented in the 
software emulator. An exception handler may be coded in the RISC instruction set, which may 
have accessibility to the general registers inaccessible to the CISC instruction set. The emulator 
may be coded in an instruction set other than the instruction set decoded by the CISC instruction 

25 decoder. Entry to the software emulator is by exception inserted into the execution unit by the 
instruction decoder. Exceptions to enter the software emulator may use the same pipeline and 
architectural infrastructure as other exceptions raised by the instruction decoder or instruction 
execution unit. The instruction decoder may be designed, when decoding an instruction to write 
multiple operands to memory, to keep intermediate state of the instruction in the inaccessible 

30 registers. The instruction decoder may be designed to store a single datum in parts in two or 
more of the registers. The instruction decoder is designed to generate instructions to store a 
single datum in parts in a plurality of the inaccessible registers, and to validate the single datum. 
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The instruction decoder may be designed to generate an instruction to compute a condition value 
into a one of the inaccessible registers during execution of a single instruction of the instruction 
set. The instruction decoder may be further designed to generate an instruction to branch based 
on the condition value, and to leave the condition value dead before completion of the single 

5 instruction. The instruction decoder, general register file, and instruction execution pipeline of 
the computer may be cooperatively designed, such that execution of at least some single 
instructions results in computing multiple intermediate results being stored in a single 
inaccessible register. All operations of the instructions in the instruction set that may generate 
exceptions may be processed before any side effects of the instruction are committed to 

10 resources accessible in the first instruction set. 

In general, in a fifty-eighth aspect, the invention features a method and computer for 
performance of the method. Instructions of a complex instruction set are decoded and executed. 
Information describing the decoding of the complex instructions is stored into architecturally- 
visible processor registers of the computer. 

1 5 In general, in a fifty-ninth aspect, the invention features a method and computer for 

performance of the method. A program is executed in user state of a computer, the program 
coded in an instruction set having many instructions with multiple side-effects and the potential 
to raise multiple exceptions. In response to recognizing an exception occurring in an instruction 
after a first side-effect of the instruction has been architecturally committed, control is 

20 transferred to a software exception handler for tiie first exception. After completion of the 

exception handler, execution of the excepted instruction is resumed, processor registers of the 
computer being designed to architecturally expose sufficient information about the intermediate 
state of the excepted instruction that the transfer and resume are effected without saving 
intermediate results of the excepted instruction on a memory stack. 

25 In general, in a sixtieth aspect, the invention features a method and computer for 

performance of the method. While decoding a sequence of computer instructions for execution 
in a multi-stage execution pipeline and before commencing substantial execution of each 
decoded instruction of the sequence, information descriptive of the instruction is generated, and, 
depending on a determination of whether the instruction will complete in the pipeline, stored or 

30 not stored into a non-pipelined register of the computer. 

In general, in a sixty-first aspect, the invention features a method and computer for performance 
of the method. 27.46. While executing a program coded in an instruction set exposed for 
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execution by programs stored in a main memory of the computer, an exception occurring in a 
program is recognized, and in response, information is architecturally exposed in processor 
registers of the computer describing a processor state of the computer. Execution is transferred 
to an exception handler. After completion of the exception handler, execution of the excepted 

5 program resumes based on the information in the processor registers. The processor registers 
and general purpose registers of the computer architecturally expose sufficient processor state 
and provide sufficient working storage for execution of the exception handler and resumption of 
the program, without storing processor state to the main memory. 

In general, in a sixty-second aspect, the invention features a method and computer for 

10 performance of the method. Instructions are fetched in a first external instruction set from a 

memory, and, for at least some instructions of the first instruction set, two or more instructions in 
a second form are issued into an execution pipeline. An intra-instruction program counter value 
is architecturally exposed when an instruction of the first instruction set raises an exception at an 
intermediate point. 

1 5 Embodiments may include one or more of the following features. The processor register 

circuitry may be designed to abstain from storing information into the processor registers during 
execution of at least some of the software exception handlers. The decoding information may 
present information about the instructions of the complex instruction set in a form uniform across 
most of the complex instruction set. In a mask register of bits, each bit corresponding to a class 

20 of instructions of the instruction set, a value of each bit may designate whether to raise an 

exception on execution of an instruction of the corresponding class. The architecturally- visible 
processor registers may not be architecturally-visible in the complex instruction set, but only in 
an alternative instruction set of the computer, the alternative instruction set being architecturally 
available to user-state programs. The decoding information may include a designation of any 

25 prefix to the current instruction, or a designation of an operand effective address, or a sign- 
extended value of an immediate value, or a designation of a length of the currently-executing 
instruction, or a designation of a current instruction pointer and an instruction pointer to a next 
instruction, or an intra-instruction fractional instruction pointer of the complex instructions, or a 
protection mode of the computer, or a designation of a base register and offset of an operand 

30 effective address, or a designation of a repeat prefix to the current instruction. The operation of 
the exception handler may be controlled at least in part by the contents of the processor registers. 
Intermediate results of the muftiple side-effect instructions may be stored in general purpose 
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registers of the computer, and those registers may not be architecturally addressable in the 
instruction set decoded by the instruction decoder. The execution pipeline and instruction 
decoder may be designed to retire instructions individually and independently, with at most a 
few interactions between instructions to affect retirement. A software exception handler may be 
5 coded to determine a location of an operand of the instruction based on the intra-instruction 
program counter value. The intra-instruction program counter value may be a serial count of 
instructions issued by the instruction decoder in response to decoding an instruction of the CISC 
instruction set. The intra-instruction program counter value may have a reserved value to 
indicate that the instruction decoder is currently in a mode to fetch instructions in the second 
1 0 form from a memory of the computer. 

In general, in a sixty-third aspect, the invention features a method and computer for 
performance of the method. On a single computer, a first operating system coded in a RISC 
instruction set and a second operating system coded in a CISC instruction set are executed 
concurrently, the CISC operating system being unmodified for execution on the computer of the 
1 5 RISC instruction set. An exception occurring during execution of a program coded in the RISC 
instruction set is accepted, and routed for handling in the CISC operating system. 

In general, in a sixty-fourth aspect, the invention features a method and computer for 
performance of the method. In response to an exception raised while executing a program coded 
in instructions of a first instruction set architecture, an execution thread is initiated under an 
20 operating system coded in instructions of a second instruction set architecture. The exception is 
delivered to the initiated thread for handling by the operating system. 

Embodiments of the invention may include one or more of the following features. An 
exception occurring during execution of a program coded in the CISC instruction set may be 
routed for handling in the RISC operating system, or vice-versa. The RISC operating system 
25 may include a collection of interrupt service routines programmed to emulate instructions in the 
CISC instruction set. Acceptance of the exception occurring at an intermediate point of 
execution of a CISC instruction may be delayed until an CISC instruction boundary. An 
exception handler coded in the RISC instruction set may save a portion of the context of the 
computer, and alter the context of the excepted program before delivering the exception to the 
30 CISC operating system. The RISC operating system may build an exception frame on a memory 
stack before tending execution to the CISC operating system. The exception may be a 
synchronous fauU generated by a RISC instruction. The exception may be a trap requesting a 
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file access service from the CISC operating system on behalf of the program. Some exceptions 
may be handled in part in each of the CISC and RISC operating systems. 

In general, in a sixty-fifth aspect, the invention features a method and computer for 
performance of the method. During execution of an instruction on a computer, in response to an 
5 operation of the instruction calling for an architecturally-visible side-effect in an architecturally- 
visible storage location, a value representative of an architecturally- visible representation of the 
side-effect is stored, a format of the representative value being different than an architecturally- 
visible representation of the side-effect. Execution resumes without generating the 
architecturally-visible side-effect. Later, the architecturally-visible representation corresponding 
10 to the representative value is v^itten into the architecturally-visible storage location. 

In general, in a sixty-sixth aspect, the invention features a method and computer for 
performance of the method. A context of a first process is stored, and a context of a second 
process is loaded to place the second process into execution, each context comprising a set of 
resources to be reloaded whenever a process associated with the context is reloaded for 
15 execution. At least some instructions executed in a multi-stage execution pipeline of the 

computer maintain results in storage resources outside the context resource set. Instructions for 
execution by the pipeline are marked to indicate whether or not a context switch may be 
performed at a boundary of the marked instruction. 

In general, in a sixty-seventh aspect the invention features a method and computer for 
20 performance of the method. During hardware execution of an instruction stream, a condition is 
recognized that is a superset of a condition whose occurrence is desired to be detected. A first 
exception is raised as a resuh of recognizing the superset condition. Software filters the superset 
condition to determine whether the desired condition has occurred. If the desired condition is 
determined to have occurred, a second exception is established to be raised after execution of 
25 further instructions of the instruction stream. 

In general, in a sixty-eighth aspect, the invention features a method and computer for 
performance of the method. During execution of a program on a computer, a condition is 
recognized in which an instruction is to affect the execution of a second instruction. In response, 
the processor is set into single-step mode. A single-step exception is taken after executing the 
30 second instruction. The processor is set out of single-step mode. 

Embodiments of the invention may include one or more of the following features. The 
later writing may be triggered by a read of the architecturally-visible storage location, or 
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completion of the execution of the instraction The architecturally- visible storage location may 
include a floating-point instruction pointer, a floating-point data pointer, and/or a floating-point 
opcode. The representative value may be held in a temporary register until several other side- 
effects are also ready to be committed to the architecturally-visible storage location 

5 simultaneously. The representative value may be held in a non-addressable storage register, and 
a process of the instruction may only cede control on an instruction boundary, so that the non- 
addressable information is not lost. The storage location may be a location in main memory or a 
cache memory, or a general purpose register of the computer having no address in an address 
space of the computer. The context switch may be triggered in response to an action of a non- 

10 final one of the instructions generated by decoding. The instructions may be marked by a marker 
on an intermediate one of the instructions generated by decoding an external-form instruction 
fetched from memory, the marker indicating an iteration boundary of an external-form 
instruction specifying repeated execution of an operation. The desired condition may be a 
memory reference to a narrow range of addresses, and the superset condition may be a memory 

1 5 reference to a broader range of addresses. The broader range of addresses may be a cache line. 
The monitored condition may be a memory reference to an address of a reference class, and the 
superset condition may be a memory reference to the address, without respect to reference class. 
The filtering software may record the nature of the monitored condition that has occurred, and 
may record multiple occurrences of desired conditions before the second exception is raised. 

20 The second exception may vector to a debug entry point of an operating system. The condition 
may be an exception recognized on one of a plurality of instructions generated by a single 
instruction fetched from a memory, and the second exception may be deferred until an 
instruction boundary of the instruction fetched from memory. The first instruction may write a 
stack segment register. Servicing a single-step exception may includes querying a debug touch 

25 record. The first instruction may be one that writes an interrupt enable flag of the computer. 

In general, in a sixty-ninth aspect, the invention features a method and computer for 
performance of the method. An instruction opcode calls for a memory reference to effect a 
movement of data. A memory protection check performed by the instruction is effective to 
check for permission to effect a movement of data other than the data movement called for by 

30 the instruction opcode. 

Embodiments of the invention may include one or more of the following features. The 
instruction may additionally perform the memory protection check associated with the data 
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movement called for by the instraction opcode, or may perform the data movement called for by 
the instruction opcode, or may omit the data movement called for by the instruction opcode. The 
instruction opcode may call for a load from memory. The instruction may perform a memory 
protection check associated with a store to memory, or v^ith an instruction fetch. 

5 In general, in a seventieth aspect, the invention features a method and computer for 

performance of the method. A younger instruction is partially executed in a portion of an 
instruction pipeline above an issue buffer of a compute. Based on that partial execution, 
completion of an instruction older than the younger instruction is prevented. 

In general, in a seventy-first aspect, the invention features a method and computer for 

10 performance of the method, A younger one of tv^o instructions received at an earlier one of two 
pipeline stages of a computer is analyzed to determine whether the younger instruction will fault 
in execution later in the pipeline. If the analysis determines that the younger instruction will 
fault, both the younger instruction and an older of the two instructions are nullified before either 
instruction irreversibly commits an architecturally-visible side-effect. If the analysis determines 

1 5 that the younger instruction will not fault, both instructions are allowed to be executed by the 

pipeline, with no further interlocking to ensure that neither instruction will prevent completion of 
the other. 

In general, in a seventy-second aspect, the invention features a method and computer for 

performance of the method. Two instructions are issued to an execution pipeline of a computer. 
20 A memory protection check is performed on an effective address referenced by a younger of the 

two instructions. Based on the memory protection check of the younger instruction, any effect of 

the older of the two instructions may be cancelled. 

In general, in a seventy-third aspect, the invention features a method and computer for 

performance of the method. During execution of a control transfer instruction in an execution 
25 pipeline of a computer, a memory segment offset of a destination address of the control transfer 

is checked against an offset limit of a segment descriptor, using the same segment limit checking 

hardware used by the execution pipeline to check a memory segment offset of memory load and 

store operations. 

Embodiments of the invention may include one or more of the following features. The 
30 younger instruction may be a control transfer instruction. The older instruction may be a write to 
a memory location. The control transfer may be a routine call and the datum written to the 
memory may be a return address. The effective address checked may be the destination of the 
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control transfer. The control transfer may be effected in a pipeline stage above an issue buffer of 
the pipeline. The control transfer may be generated in response to decoding an instruction 
calling for a decrement of a value and a control transfer based on a comparison between the 
value and zero. The earlier pipeline stage may be an instruction fetch and/or decode stage early 

5 in the pipeline. The analysis may determine whether the destination of the jump is valid for 
execution. The nullification may prevent any architecturally-visible change to machine state. 
The nullification may include reversing a committed side-effect of the older instruction. 

In general, in a seventy-fourth aspect, the invention features a method and computer for 
performance of the method. A macroinstruction of a computer is decoded to generate a number 

1 0 of iterations of (a) a pattern of microinstructions implementing a basic operation, and (b) a 
branch instruction predicted not taken. 

In general, in a seventy-fifth aspect, the invention features a method and computer for 
performance of the method. A macroinstruction is decoded to call for a number of iterations of a 
sequence of one or more microinstructions. On detecting that an iteration completes operation of 

1 5 the macroinstruction, a marker indicating the end of the macroinstruction is added to a 
microinstruction in the pipeline downstream of the instruction decoder. 

In general, in a seventy-sixth aspect, the invention features a method and computer for 
performance of the method. After g a termination condition of a loop of a first microinstruction 
stream is reached, a partial loop iteration beyond the termination is executed, the partial 

20 execution committing at least one side-effect to an architecturally- visible resource of the 

computer. An exception is raised to transfer control to a second microinstruction stream. In the 
second microinstruction stream, the side-effects committed by the post-termination iteration are 
unwound. 

Embodiments of the invention may include one or more of the following features. The 
25 microinstruction set may be architecturally exposed to programs fetched fi-om a memory of the 
computer. Instructions of the microinstruction set may be managed by a memory management 
unit between a main memory of the computer and one or more cache levels. The instruction 
decoder may be designed to cease generating iterations when a termination condition of the 
macroinstruction is detected in the instruction pipeline. The termination condition may include 
30 detection of a branch mispredict. The mispredicted branch microinstruction may be a branch 
instruction available to a program fetched from a memory of the computer. The branch 
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microinstruction may be generated carrying a marker indicating that the branch microinstruction 
defines a boundary between two successive iterations. 

In general, in a seventy-seventh aspect, the invention features a method and computer for 
performance of the method. A computer executes instructions in first and second instruction 

5 sets. A first instruction coded in the first instruction set stores into a memory location a value of 
a second instruction coded in the second instruction set. In response to the storing, a memory 
system and execution pipeline are cleared of the former content of the memory location. The 
second instruction is executed in the execution pipeline. 

Embodiments of the invention may include one or more of the following features. An 

10 instruction decoder for the second instruction set may be designed to generate instructions in the 
first instruction set for execution in the execution pipeline. The instructions in the execution 
pipeline may not be tagged with an indication of an instruction set of origin. The monitoring 
may be based on comparing addresses in a physical address space. 

In general, in a seventy-eighth aspect, the invention features a method and computer for 

15 performance of the method. Execution of an instruction includes the steps of waiting to allow a 
pipeline to drain, and setting bits of a floating-point control word to values denoted in an explicit 
immediate field of the instruction. 

Embodiments of the invention may include one or more of the following features. 
Instruction fetch and execution circuitry of the computer may be designed to fetch and execute a 

20 macroinstruction set and a microinstruction set from memory. The instruction may be generated 
to implement a macroinstruction whose execution is dependent on a fiill/empty state of a 
floating-point top-of-stack. The instruction may specify individual bits of the floating-point 
control word to be written, in addition to values to be written to those bits. The computer may 
also provide an instruction calling for waiting to allow a pipeline to drain and to raise an 

25 exception based on a test of bits of a floating-point control word. 

Embodiments of the invention may offer one or more of the following advantages. 
A program produced for a computer of an old architecture can be executed on a computer 
of a new architecture. The old binary can be executed without any modification. Old binaries 
can be mixed with new — for instance, a program coded for an old architecture can call library 

30 routines coded in the new instruction set, or vice- versa. Old libraries and new libraries may be 
freely mixed. New and old binaries may share the same address space, which improves the 
ability of new and old binaries to share common data. Alternatively, an old binary can be run in 
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a protected separate address space on a new computer, without sharing any data with any new 
binary. A caller need not be aware of the ISA in which the callee is coded, avoiding the burden 
of explicitly saving and restoring context. The invention reduces software complexity: software 
need not make explicit provision for all possible entries and exits from all possible modes and 

5 mixtures of binaries. The pipelines for processing old instructions and new instructions can 
share pieces of the implementation, reducing the cost of supporting two instruction sets. A new 
computer can fully model an older computer, with no reliance on any software convention that 
may be imposed by any particular software product, allowing the new computer to run any 
program for the old computer, including varying off-the-shelf operating systems. Because 

1 0 translated target code is tracked in association with the physical pages of the source code, even if 
the physical pages are mapped at different points in the virtual address spaces, a single 
translation will be reused for all processes. This is particularly advantageous in the case of 
shared libraries. 

The profile data may be used in a "hot spot" detector, that identifies portions of the 

15 program as frequently executed. Those frequently-executed portions can then be altered, either 
by a programmer or by software, to run more quickly. The profile data may be used by a binary 
translator to resolve ambiguities in the binary coding of instructions. The information generated 
by the profiler is complete enough that the hot spot detector can be driven off the profile, with no 
need to refer to the instruction text itself. This reduces cache pollution. Ambiguities in the X86 

20 instruction text (the meaning of a given set of instructions that cannot be inferred from the 
instruction text, for instance the operand size information from the segment descriptors) are 
resolved by reference to the profile information. The information collected by the profiler 
compactly represents the information needed by the hot spot detector and the binary translator, 
with relatively little overhead, thereby reducing cache pollution. The profiler is integrated into 

25 the hardware implementation of the computer, allowing it to run fast, with little delay on a 
program - the overhead of profiling is only a few percent of execution speed. 

Control may be transferred from an unoptimized instruction stream to an optimized 
instruction stream, without any change to the unoptimized instruction stream. In these cases, the 
unoptimized instruction stream remains available as a reference for correct execution. The 

30 instruction stream may be armotated with information to control a variety of execution 
conditions. 
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A profile may be used to determine which program transformation optimizations are safe 
and correct, and which present a risk of error. Rather than foregoing all opportunities unsafe 
optimizations or speed-ups, the optimization or speed-up may be attempted, and monitored for 
actual success or failure. The slower, unoptimized mode of execution can be invoked if the 
optimization in fact turns out to be unsafe. 

A single instruction coding can be used both as a RISC instruction set, exposed to 
programmers and compilers, and as a microcode instruction set. This improves design 
testability, and reduces the amount of design. Programs are able to exploit the full performance 
and flexibility of the microarchitecture. The native microinstructions are simple. Individual 
microinstructions execute almost entirely independent of their context - a given instruction 
always performs the same operation, without reference to previous or following instructions. 
The amount of interlocking between consecutive instructions is reduced. Much of the 
complexity of implementing a complex instruction set, such as the X86 instruction set, is 
removed from the hardware, and moved into a software emulator, where errors are easier to 
avoid, detect, and correct. 

Individual instructions execute and retire with very little contextual reference to earlier or 
later instructions. The execution behavior of a native instruction is determined by the opcode 
bits of the instruction, and the contents of the registers named as explicit operands, and only 
rarely on machine mode, instruction sequence, or other context. The instructions require very 
little annotation beyond the information that is normally and naturally contained in simple 
load/store/operate types of instructions. For instance, native Tapestry instructions perform the 
same functions whether received from a native Tapestry binary, or generated by the converter 
from an X86 instruction. Instructions generated by the converter perform the same functions 
whether they are the first instruction in a recipe for an X86 instruction, the last instruction of a 
recipe, or an instruction in the middle of a recipe. 

Instructions retire individually. That is, once the side-effects (resuhs written to 
architecturally-visible registers or to memory, transfers of control, exceptions, etc.) of an 
instruction are committed, they need not be further tracked for backing-out by a later instruction. 
The native instructions that constitute a recipe for an X86 instruction can be retired individually, 
without the need to collect the side-effects for all native instructions of the recipe. Individual 
retirement allows simplification of the hardware, and reduces some critical paths. The 
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"accounting" is simplified if side-effects are committed as individual instructions are retired, 
rather than collected among multiple instructions to be committed as a group. 

Individual mechanisms are designed to be generally applicable, to be shared among many 
needs. For instance, the exception interface is designed to support both traditional exceptions, 

5 and intra-instruction exceptions transferring execution to the software emulator. Returning from 
the emulator is very much like returning from any other exception in a traditional machine. The 
general register file is designed for traditional use as a register file, and to hold intra-instruction 
intermediate results while execution proceeds within the converter. The processor register 
mechanism is broadly applicable to both traditional machine control functions and to control of 

10 the interface between X86 execution in hardware, X86 execution in software, and emulation of 
complex X86 functionality such as single-stepping, debug, and the like. 

The hardware is kept relatively simple by moving much of the complex behavior of the 
X86 into a software emulator. The emulator is invoked by the mechanism used for other 
machine exceptions. The complex X86 functions that are used in nearly every instruction, such 

15 as the complex X86 segmentation and paging behavior, is implemented in hardware, to improve 
performance. For instance, the inhibition of interrupts between certain pairs of X86 instructions 
is implemented in software rather than hardware. 

The above advantages and features are of representative embodiments only, and are 
presented only to assist in understanding the invention. Additional features and advantages of 

20 the invention will become apparent in the following description, from the drawings, and from the 
claims. 

DESCRIPTION OF THE DRAWING 
Figs, la, lb, Ic, Id, 3a and 9a are block diagrams of a computer system. 
25 Fig. le is a diagram of a PSW (program status word) of a system as shown in Figs. la- 

Id. 

Fig. 2a is a table relating the meaning of several bits of the PSW of Fig. le. 
Figs. 2b and 2c are tables relating the actions of exception handlers. 
Figs. 3b, 3c, 3d, 3e, 3f, 31, 3m, 3n and 3o are block diagrams showing program flow 
30 through memory. 

Figs. 3g, 3h, 3i, 3j, 6c, 7d, 8b, and 8c are flow diagrams. 

Fig. 3k, 4c, 4d, and 7j show data declarations or data structures. 
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Fig. 4a, 4e and 4f are block diagrams showing program flow through memory, and 
profile information describing that program flow. 

Fig. 4b is a table of profiling event codes and their meanings. 

Figs. 4g, 4h, 4i, 7c, 7i, 8a and 9b show processor registers of the computer. 
5 Fig. 5a shows a finite state machine for control of a profiler. 

Figs. 5b, 6b, 7a, 7b, 7e, 7f, 7g, and 7h are circuit block diagrams. 

Fig. 6a is a block diagram of PIPM (Physical IP map) and an entry thereof. 

Fig. 9c is a data structure diagram showing instructions of the computer. 

Fig. 9d is a table showing information connected with instructions of the computer. 
10 Fig. 9f is a table showing use of temporary registers by the converter. 

Figs. 9e, 9g, 9h, 9i, 9j and 9k show pseudocode of X86 instructions and corresponding 
native Tapestry instructions. 



DESCRIPTION 

1 5 The description is organized as follows. 

I. Overview of the Tapestry system, and features of general use in several aspects of the 

invention 

A. System overview 

B. The Tapestry instruction pipeline 

20 C. Address translation as a control point for system features 

D. Overview of binary translation, TAXi and the converter safety net 

E. System- wide controls 

F. The XP bit and the unprotected exception 

II. Indicating the instruction set architecture (ISA) for program text 

25 III. Saving Tapestry processor context in association with an X86 thread 

A. Overview 

B. Subprogram Prologs 

C. X86-to-Tapestry transition handler 

D. Tapestry-to-X86 transition handler 

30 E. Handling ISA crossings on interrupts or exceptions in the Tapestry operating system 

F. Resuming Tapestry execution from the X86 operating system 

G. An example 
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H. Alternative embodiments 
IV. An alternative method for managing transitions from one ISA to the other 

A. Indicating the calling convention (CC) for program text 

B. Recording Transfer of Control Semantics and Reconciling Calling Conventions 
5 V. Profiling to determine hot spots for translation 

A. Overviev^ of profiling 

B. Profileable events and event codes 

C. Storage form for profiled events 

D. Profile information collected for a specific example event - a page straddle 
10 E. Control registers controlling the profiler 

F. The profiler state machine and operation of the profiler 

G. Determining the five-bit event code from a four-bit stored form 

H. Interaction of the profiler, exceptions, and the XP protected/unprotected page property 

I. Alternative embodiments 
15 VI. Probing to find a translation 

A. Overview of probing 

B. Overview of statistical probing 

C. Hardware and software structures for statistical probing 

D. Operation of statistical probing 
20 E. Additional features of probing 

F. Completing execution of TAXi code and returning to the X86 code 

G. The interaction of probing and profiling 

H. Alternative uses of adaptive opportunistic statistical techniques 
VII. Validating and invalidating translated instructions 

25 A. A simplified DMU model 

B. Overview of a design that uses less memory 

C. Sector Monitoring Registers 

D. Interface and Status Register 

E. Operation 
30 F. Circuitry 

G. DMU_Status register 

H. DMU_Command register 
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VIII. Managing out-of-order effects 

A. Ensuring in-order handling of events reordered by optimized translation 

B. Profiling references to non-well-behaved memory 

C. Reconstructing canonical machine state to arrive at a precise boundary 
5 D. Safety net execution 

IX. The converter 

A. Overview 

1 . Pipeline structure, and translation recipes 

2. The emulator 

10 3. Side-band information: frac bits, instruction boundaries, interruptible points, etc. 

4. Interrupts, traps, and exceptions 

5. The frac bits, and continuing a recipe 

6. Expansion from external form to internal formatted form 

B. Individual retirement of instructions 
15 1 . Recipe use of temporary registers 

2. Memory reference instructions that trigger protection checks suited for a 
different reference class 

3. Target limit check instruction 

20 a. LOAD/STORE and branch limit checks 

b. Target limit check for near register-relative CALL 

4. Special grouping of instructions to ensure co-atomic execution. 

5. Far calls 

6. Unwind in the emulator of LOOP instruction 
25 7. Repeated string instructions 

C. Collecting results of multiple native instructions to emulate multiple side-effects of a 
single X86 instruction 

1. Load/store address debug comparison result gathering and filtering 
30 2. FP-DP/IP/OP postponement 

3. STIS (store into instruction stream) flush boundary to next instruction 

D. An externally-exposed RISC ISA as microinstruction set - implementing a second 
instruction set conversion and implementation with a user-accessible first instruction 
set 

35 
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1 . External microcode 

2. Miscellaneous features 

E. Restartable complex instructions 

1 . Atomic MOV/POP stack segment pair via native single-step 

2. IF bit change inhibition via native single-step 

F. The FWAIT instruction 
X. Interrupt priority 



I. Overview of the Tapestry system, and features of general use in several aspects of 
10 the invention 

A. System overview 

Referring to Figs, la, lb and Ic, the invention is embodied in the Tapestry product of 
Chromatic Research, Inc. of Sunnyvale, CA. Tapestry is fast RISC processor 100, with 
hardware and software features that provide a correct implementation of an Intel X86-family 

15 processor. ("X86" refers to the family including the 8086, 80186, ... 80486, Pentium, and 
Pentium Pro. The family is described in Intel Architecture Software Developer's 
Manual, vol. 1-3, Intel Corp. (1997)) Tapestry fully implements the X86 architecture, in 
particular, a full Pentium with MMX extensions, including memory management, with no 
reliance on any software convention imposed, for instance, by a Microsoft or IBM operating 

20 system. A Tapestry system will typically be populated by two to four processors (only one of 
which is shown in Figs, la, lb and Ic), interconnected as symmetric shared memory 
multiprocessors. 

Tapestry processor 100 fetches (stage 110) instructions from instruction cache (I-cache) 
112, or from memory 118, from a location specified by IP (instruction pointer, generally known 

25 as the PC or program counter in other machines) 114, with virtual-to-physical address translation 
provided by I-TLB (instruction translation look-aside buffer) 116. The instructions fetched from 
I-cache 112 are executed by a RISC execution pipeline 120. In addition to the services provided 
by a conventional I-TLB, I-TLB 116 stores several bits 182, 186 that choose an instruction 
environment in which to interpret the fetched instruction bytes. One bit 182 selects an 

30 instruction set architecture (ISA) for the instructions on a memory page. Thus, the Tapestry 
hardware can readily execute either native instructions or the instructions of the Intel X86 ISA. 
This feature is discussed in more detail in section II, infra. 



Atty. Docket No. 30585/28 

NYDOCS04/ 285781 



42 



Express Mail Label EI465234796US 



The execution of a program encoded in the X86 ISA is typically slower than execution of 
the same program that has been compiled into the native Tapestry ISA. Profiler 400 records 
details of the execution flow of the X86 program. Profiling is discussed in greater detail in 
section V, infra. Hot spot detector 122 analyzes the profile to find "hot spots," portions of the 

5 program that are firequently executed. When a hot spot is detected, a binary translator 124 

translates the X86 instructions of the hot spot into optimized native Tapestry code, called "TAXi 
code." During emulation of the X86 program, prober 600 monitors the program flow for 
execution of X86 instructions that have been translated into native code. When prober 600 
detects that translated native Tapestry code exists corresponding to the X86 code about to be 

10 executed, and some additional correctness predicates are satisfied, prober 600 redirects the IP to 
fetch instructions from the translated native code instead of from the X86 code. Probing is 
discussed in greater detail in section VI, infra. The correspondence between X86 code and 
translated native Tapestry code is maintained in PIPM (Physical Instruction Pointer Map) 602. 
Because the X86 program text may be modified while under execution, the system 

15 monitors itself to detect operations that may invalidate a previous translation of X86 program 
text. Such invalidating operations include self-modifying code, and direct memory access 
(DMA) transfers. When such an operation is detected, the system invalidates any native 
Tapestry translation that may exist corresponding to the potentially-modified X86 text. 
Similarly, any other captured or cached data associated with the modified X86 data is 

20 invalidated, for instance profile data. These validity-management mechanisms are discussed in 
greater detail in sections I.F, VII and VIII, infra. 

The system does not translate instructions stored in non-DRAM memory, for instance 
ROM BIOS for I/O devices, memory-mapped control registers, etc. 

Storage for translated native Tapestry code can also be released and reclaimed under a 

25 replacement policy, for instance least-recently-used (LRU) or first-in-first-out (FIFO). 

A portion of the X86 program may be translated into native Tapestry code multiple times 
during a single execution of the program. Typically, the translation is performed on one 
processor of the Tapestry multiprocessor while the execution is in progress on another. 

For several years, Intel and others have implemented the X86 instruction set using a 

30 RISC execution core, though the RISC instruction set has not been exposed for use by programs. 
The Tapestry computer takes three new approaches. First, the Tapestry machine exposes both 
the native RISC instruction set and the X86 instruction set, so that a single program can be coded 
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in both, with freedom to call back and forth between the two. This approach is enabled by ISA 
bit 180, 182 control on converter 136, and context saving in the exception handler (see sections 
II and III, infra), or in an alternative embodiment, by ISA bit 180, 182, calling convention bit 
200, semantic context record 206, and the corresponding exception handlers (see section IV, 

5 infra). Second, an X86 program may be translated into native RISC code, so that X86 programs 
can exploit many more of the speed opportunities available in a RISC instruction set. This 
second approach is enabled by profiler 400, prober 600, binary translator, and certain features of 
the memory manager (see sections V through VIII, infra). Third, these two approaches 
cooperate to provide an additional level of benefit. 

10 Most of the features discussed in this disclosure are under a global control, a single bit in 

a processor control register named "PP_enable" (page properties enabled). When this bit is zero, 
ISA bit 180, 182 is ignored and instructions are interpreted in Tapestry native mode, profiling is 
disabled, and probing is disabled. 

15 B. The Tapestry instruction pipeline 

Referring to Figs. Ic and 9a, a Tapestry processor 100 implements an 8- or 9-stage 

pipeline. Stage 1 (stage 110) fetches a Une from I-cache 112. Stages 2 (Align stage 130) and 3 
(Convert stage 134, 136, 138) operate differently in X86 and native Tapestry modes. In native 
mode, Align stage 130 runs asynchronously from the rest of the pipeline, prefetching data from 

20 I-cache 112 into elastic prefetch buffer 132. In X86 mode. Align stage 130 partially decodes the 
instruction stream in order to determine boundaries between the variable length X86 instructions, 
and presents integral X86 instructions to Convert stage 134. During X86 emulation, stage 3, 
Convert stage 134, 136 decodes each X86 instruction and converts 136 it into a sequence of 
native Tapestry instructions. In decomposing an X86 instruction into native instructions, 

25 converter 136 can issue one or two Tapestry instructions per cycle. Each Tapestry processor 100 
has four parallel pipelined functional units 156, 158, 160, 162 to implement four- way superscalar 
issue of the last five stages of the pipeline. In native mode, convert stage 134, 138 determines up 
to four independent instructions that can be executed concurrently, and issues them downstream 
to the four superscalar execution pipelines. (In other machine descriptions, this is sometimes 

30 called "slotting," deciding whether sufficient resources and fiinctional units are available, and 
which instruction is to be issued to which fiinctional unit.) The Decode stage 140 (or "D-stage"), 
Register-read stage 142 (or "R-stage"), Address-Generate stage 144 (or "A- stage"). Memory 
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stage 146 (or "M-stage"), Execute stage 148 (or "E-stage"), and Write-back stage 150 (or "W- 
stage") may be considered to be conventional RISC pipeline stages, at least for purposes of the 
inventions disclosed in sections I-VIII. The pipeline will be further elaborated in the discussion 
of Figs. 9a-9c5 in section IX. 

5 Converter 136 decodes each X86 instruction and decomposes it into one or more simple 

Tapestry instructions. The simple instructions are called the "recipe" for the X86 instruction. 

Referring to Table 1, when X86 converter 136 is active, there is a fixed mapping between 
X86 resources and Tapestry resources. For instance, the EAX, EBX, ECX, EDX, ESP and EBP 
registers of the X86 architecture are mapped by converter hardware 136 to registers R48, R49, 

1 0 R50, R5 1 , R52 and R53, respectively, of the Tapestry physical machine. The eight floating- 
point registers of the X86, split into a 16-bit sign and exponent, and a 64-bit firaction, are mapped 
to registers R32-47. The X86 memory is mapped to the Tapestry memory, as discussed in 
section I.C, infra. 

The use of the registers, including the mapping to X86 registers, is summarized in Table 
15 1. The "CALL" column describes how the registers are used to pass arguments in the native 

Tapestry calling convention. (Calling conventions are discussed in detail in sections III. A, IILB, 
and IV, infra) The "P/H/D" column describes another aspect of the Tapestry calling convention, 
what registers are preserved across calls (if the callee subprogram modifies a register, it must 
save the register on entry and restore it on exit), which are half-preserved (the low-order 32 bits 
20 are preserved across calls, but the upper 32 bits may be modified), and which are destroyable. 
The "X86 p/d" column shows whether the low-order 32 bits of the register, corresponding to a 
32-bit X86 register, is preserved or destroyed by a call. The "Converter," "Emulator" and 
"TAXi" cQlumns show the mapping between Tapestry registers and X86 registers under three 
different contexts. For registers r32-r47, "hi" in the X86 columns indicates that the register 
25 holds a 1 6-bit sign and exponent portion of an X86 extended-precision floating-point value, and 
"lo" indicates the 64-bit fraction. 
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X86 code will preserve only low 32 bits 
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edi 


edi 


edi 


r54 




H 


X86 code will preserve only low 32 bits 


P 


esi 


esi 


esi 


r53 


[FP] 


H 


must be Frame-Pointer if stack frame has variable size. 
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ebp 


ebp 


ebp 


r52 


SP 
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stack pointer 


P 


esp 


esp 


esp 


r51 


RV3 


D 


if (192 bits < size <= 256 bits) fourth 64 bits of function result 


d 


ebx ~ 


ebx 


ebx 


r50 


RV2 


D 


X86 _fastcall 2nd arg; 

if (128 bits < size <= 256 bits) third 64 bits of function result 
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edx 


edx 


edx 


r49 


THIS 
RVl 
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X86_fastcall 1st arg; 

thiscalr object address (unadorned C++ non-static method); 
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X86 function result 
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eax 


eax 
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r47 


P15 
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parameter register 15 




f7-hi 


f7-hi 
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P14 


D 


parameter register 14 




f7-lo 


f7-lo 


f7-lo 


r45 


P13 


D 


parameter register 13 
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parameter register 12 
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f6-lo 


-43" • 


Pll 


D 


parameter register 1 1 
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parameter register 10 
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parameter register 9 
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parameter register 8 
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parameter register 7 
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parameter register 6 
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parameter register 5 
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parameter register 4 




f2-lo 


f2-lo 


f2-lo 


r35 


P3 


D 


parameter register 3 
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parameter register 1 
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DP floating-point function result 
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Cross-ISA transfer descriptor (both call and return) 
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rl4 




D 








CTIO 
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rlO 




D 








CT6 
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D 


pointer to global static environment (per-image) 
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LR 


D 


linkage register 
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D 


argument list pointer (overflow arguments in memory) 
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r4 


AT 


D 








AT 








vol 


VOlaliiC, lllay UXllj UC UoCU 111 CA^^CpUUll licUlUlCio 


vol 


vol 


vol 


vol 


r2 




vol 


volatile, may only be used in exception handlers 
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volatile, may only be used in exception handlers 
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always zero 


n/a 


n/a 
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RO is read-only always zero. During X86 emulation, R1-R3 are reserved for exception 
handlers. R4 is an assembler temporary for use by the assembler to materialize values that 
cannot be represented as immediates. During X86 emulation, R15-R31 are assigned to use by 
5 profiler 400, as discussed in section V, infra, and R5-R14, designated as "CTl" through "CTIO," 
are reserved for use as "converter temporaries," as discussed in section IX.B.l . 

Tapestry supersets many features of the X86. For instance, the Tapestry page table 
format is identical to the X86 page table format; additional information about page frames is 
stored in a Tapestry-private table, the PFAT (page frame attribute table) 172, as shown in Fig. 
10 Id. As will be shown in Fig. le, the Tapestry PSW (Program Status Word) 190 embeds the X86 
PSW 192, and adds several bits. 

The Tapestry hardware does not implement the entire X86 architecture. Some of the 
more baroque and less-used features are implemented in a software emulator (316 of Fig. 3a). 
The combination of hardware converter 136 and software emulator 316, however, yields a full 
1 5 and faithfiil implementation of the X86 architecture. 

One of the features of emulator 316 is elaborated in section III, infra. The interaction 
between hardware converter 136 and software emulator 316 is elaborated in section IX in 
general, and more particularly in sections IX.A.2, IX.B.6, IX.C, and IX.E, infra, 

20 C. Address translation as a control point for system features 

Referring to Fig. Id, X86 address translation is implemented by Tapestry's native 

address translation. During X86 emulation, native virtual address translation 170 is always 
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turned on. Even when the X86 is being emulated in a mode where X86 address translation is 
turned off, Tapestry address translation is turned on, to implement an identity mapping. By 
forcing every memory reference through the Tapestry address translation hardware, address 
translation becomes a convenient place for intercepting much of the activity of X86 converter 

5 136, and controlling the converter's execution. Further, control information for many features of 
the invention is conveniently stored in tables associated with, or tables analogous to those 
conventionally used for, address translation and virtual memory management. These "hooks" 
into address translation allow the Tapestry processor and software to intervene to emulate 
portions of the X86 that have "strange" behavior, like VGA graphics hardware, control registers, 

10 memory mapped device controls, and parts of the X86 address space that are given special 
treatment by traditional Intel chip sets. 

To avoid changing the meaning of any portion of storage that X86 programs might be 
using, even if that use is unconventional, the Tapestry processor does not store any of its 
information in the X86 address translation tables. Tapestry-specific information about pages is 

15 stored in structures created specifically for Tapestry emulation of the X86. These structures are 
not defined in the X86 architecture, and are invisible to the emulated X86 or any program 
executing on the X86. Among these structures are PFAT (page fi^ame attribute table) 172. 
PFAT 172 is a table whose entries correspond to physical page frames and hold data for 
processing and managing those page fi-ames, somewhat analogous to the PFN (page frame 

20 number) database of the VAXTVMS virtual memory manager (see, e.g., Lawrence Kenah and 
Simon Bate, VAX/VMS Internals and Data Structures, Digital Press, 1984, incorporated 
herein by reference). PFAT 172 has one 1-byte entry 174 corresponding to each physical page 
frame. 

As will be discussed in sections II, IV, and V and VI, infra, PFAT entries 174 also 
25 include bits that control which ISA is used to decode the instructions of the corresponding page, 
which calling convention is used on the corresponding page, and to control probing. 



D. Overview of binary translation, T AXi and the converter safety net 

Referring again to Figs, la and lb, TAXi ("Tapestry accelerated execution," pronounced 

30 "TAXi") is a binary translation system. TAXi marries two modes of execution, hardware 

converter 136 (with software assistance in the run-time system) that faithfully implements a gold 
standard implementation of the full X86 architecture, and a software binary translator 124 that 
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translates X86 binaries to Tapestry native binaries, but optimizes the translated code by making 
certain optimistic assumptions that may violate correctness. 

As a pre-existing X86 binary is executed in converter 136, hot spots (frequently-executed 
portions) in the X86 binary are recognized 122, and translated 124 on-the-fly into native 

5 Tapestry instructions. The hardware converter 136 (coupled with a software X86 emulator 316 
for especially complex instructions) is necessarily slower than the translated code, because the 
X86 instructions must be executed in strict sequence. By translating complete hot spots of an 
X86 binary, as opposed to "translating" single instructions in converter 136, more optimization 
opportunities are exposed: X86 instructions can be decomposed into small data-independent 

10 Tapestry instructions, which in turn can be executed out of order, pipelined, or executed in 
parallel in the four superscalar pipelines (156, 158, 160, 162 of Fig. Ic). 

Execution of X86 code is profiled. This profiling information is used to identify 122 the 
"hot spots" in the X86 program, the most-executed parts of the program, and thus the parts that 
can most benefit from translation into native Tapestry code. The hot spots in the X86 code are 

15 translated by translator 124 into native Tapestry code (TAXi code). As execution of the X86 

program proceeds, execution is monitored to determine whether a translated equivalent exists for 
the X86 code about to be executed. If so, execution is transferred to the translated native 
Tapestry code. 

TAXi translator 124 adopts a somewhat simplified view of the machine behavior; for 
20 instance, some X86 instructions are not translated. Translator 124 also takes an optimistic view. 
For instance, translator 124 assumes that there will be no floating-point exceptions or page faults, 
so that operations can be reordered or speculatively rescheduled without changing program 
behavior. Translator 124 also assumes that all memory references are to well-behaved memory, 
("Well-behaved memory" is a memory from which a load will receive the data last stored at the 
25 memory location. Non-well-behaved memory is typified by memory-mapped device controllers, 
also called "I/O space," where a read causes the memory to change state, or where a read does 
not necessarily return the value most-recently vsritten, or two successive reads return distinct 
data.) For instance, binary translator 124 assumes that memory reads can be reordered. 
Translated native Tapestry code runs faster than converter 136, and is used when translation can 
30 be guaranteed to be correct, or when any divergence can be caught and corrected. 

The execution of the TAXi code is monitored to detect violations of the optimistic 
assumptions, so that any deviation from correct emulation of the X86 can be detected. Either a 
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pre-check can detect that execution is about to enter a region of translated code that can not be 
trusted to execute correctly, or hardware delivers an exception after the fact when the optimistic 
assumptions are violated. In either case, when correctness carmot be guaranteed, or for code that 
translator 124 does not know how to translate, execution of the translated native Tapestry code is 
5 aborted or rolled back to a safe check point, and execution is resumed in the hardware converter 
136. The hardware converter 136 adopts the most conservative assiunptions, guaranteeing in- 
order, gold standard correctness, and serves as a safety net for the less risk-averse binary 
translator 124. 

This safety net paradigm allows binary translator 124 to be more aggressive, and makes 
10 development easier, because developers can focus on performance issues and leave correctness 
issues to be caught in the safety net. Additional'details of the safety net paradigm are discussed 
in section VIII. 

Tapestry and TAXi implement a full X86 architecture. No concession is required from 
X86 software; indeed, any X86 operating system can run on Tapestry, including off-the-shelf 

15 operating systems not specially adapted for Tapestry. Tapestry and TAXi make no assumptions 
about operating system entities, such as processes, threads, virtual address spaces, address 
mappings. Thus, Tapestry and TAXi operate in terms of the physical memory of the virtual X86, 
not the X86 virtual or linear addresses. (The distinction between Intel's "virtual" addresses and 
"linear" addresses seldom arises in the context of this disclosure; thus, unless a fine distinction 

20 between the two is required, this disclosure uses the term "virtual address" to embrace both 

concepts.) For instance, library code that is shared between different processes at the operating 
system level, by using physical addresses, is automatically shared by TAXi processes because 
the physical memory is shared on the Tapestry implementation. Code shared by the operating 
system is shared even if it is mapped at different addresses in different processes. If the 

25 processes are actually sharing the same physical page, then TAXi will share the same translated 
code. 

Buffers of translated code are recycled in a first-in-first-out (FIFO) order. Once a 
translated code buffer is marked for reclamation, it is not immediately discarded; rather it is 
marked available for reuse. If execution re-enters an available-for-reuse buffer before the 
30 contents are destroyed, the buffer is recycled to the head of the FIFO queue. In an alternative 
embodiment, whenever the buffer is entered, it is moved to the head of the FIFO queue; this 
approximates a least-recently-used (LRU) replacement policy. 
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A number of features of the TAXi system are tied to profiling. For instance, a region of 
code that is not profiled can never be identified as a hot spot, and thus will never be translated. 
Similarly, probing (see section VI, infra) is disabled for any region that is not profiled, because 
without a translation, a probe can never succeed. This invariant simplifies a number of design 
5 details, as will be discussed at various points infra. 

E. System-wide controls 

The PSW 190 has a TAXi_Active bit 198 that enables user-mode access to functionality 
that is otherwise disallowed in user mode. PSW.TAXi_Active 198 will be set true while a native 

10 Tapestry translation of an X86 program is being executed. When PSW.TAXi_Active 198 is true, 
a user-mode program may access the LDA / STA lock functionality of the X86, it has read and 
write access to all Tapestry processor registers, and it may access extended TRAP instruction 
vectors (specifically, to enable calling emulator functions). Further, X86-compatible semantics 
for extended precision floating-point operations is enabled. 

15 A successful probe will set PSW.TAXi_Active 198 before it RFE's to the TAXi- 

translated code. When the TAXi-translated code completes execution, the process of retuming to 
untranslated X86 code will clear PSW.TAXi_Active 198 before RFE'ing back to converter 136. 
If an exception occurs in the TAXi-translated code, then emulator 316 will be called to surface 
the exception back to the X86 virtual machine. Emulator 316 will check EPC.TAXi_Active 198 

20 and return control to TAXi to restore the X86 machine context and RFE back to converter 136 to 
re-execute the X86 instruction. 

F. The XP bit and the unprotected exception 

Refening again to Figs, la, lb and 2a, TAXi translator 124 produces a translation of an 
25 X86 binary. The TAXi system as a whole represents a very complex cache, where the X86 code 
represents the slower memory level and the translated TAXi code represents the faster memory 
level. TAXi begins caching information at the time of profiling, because profiling records 
knowledge about what events occurred at what addresses, where the instruction boundaries were, 
etc. Further caching occurs when binary translator 124 translates X86 code into semantically 
30 equivalent Tapestry native code. In order not to violate the X86 architectural model, TAXi 

protects against execution of translated Tapestry native code that corresponds to stale X86 code, 
X86 code that has either disappeared or been modified. If the underlying primary datum (the 
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X86 instruction text) is modified, whether by a memory write from the CPU, or by a DMA write 
from a device, the cached data (the profile describing the X86 code and the TAXi code generated 
from it) is invaUdated, so that it will not be executed. Execution will revert to the X86 text, in its 
modified form. If the modified X86 text becomes a hot spot, it may be recognized 122 and 
5 retranslated 124. 

Like an ordinary cache, the TAXi cache has a valid bit - the XP bit (184 in PIPM entry 
640, 186 in the I-TLB, see Figs, la, lb). X86 code, and the validity of the "cached" translated 
native Tapestry code, is protected against modification by CPU writes by XP write-protect bit 
184, 186, and exception handlers that manage the protection of pages. Together, the flags and 

10 exceptions maintain a coherent translated Tapestry binary as a "cached" copy of the X86 
program, while allowing the X86 program (whether encoded in its original X86 form or in 
translated native Tapestry form) to write to memory, even if that write implements self- 
modifying code. In either mode, the machine (either X86 converter 136 or the TAXi system) 
will faithfully execute the program's semantics. The protected and unprotected exceptions do 

1 5 not terminate processing in the manner of a conventional write-protect exception, but merely 
signal to the TAXi system that it must intervene to manage the validity of any TAXi code. 

When a page of X86 code is protected, that is, when its XP protected bit 184, 186 is One, 
there are two classes of events that invalidate the TAXi code associated with the X86 code. 
First, a Tapestry processor could do a store into one of the X86 pages. This could arise if the 

20 program uses self-modifying code, or if the program creates code in writeable storage (stack or 
heap) on the fly. Second, a DMA device could write onto the page, for instance, when a page of 
program text is paged in on a page fault following a program load or activation. In either case. 
Tapestry generates an interrupt, and a handler for the interrupt resets the XP "valid" bit to 
indicate that any TAXi code corresponding to the X86 page cannot be reached by a probe (recall 

25 from section VI.D that probing is only enabled on X86 pages whose XP bit 184, 186 is One). 

The write-protect bit is named "XP," originally an acronym for "extended property." 
Thus, when ISA bit (180 in PFAT 172, 182 in I-TLB) for a page indicates X86 ISA, the XP bit 
(184 in PIPM entry 640, 186 in the I-TLB) is interpreted to encode the modify-protect property 
for the page. XP bit 184, 186 controls the protection mechanism on a page-by-page granularity. 

30 The protection system for the machine as a whole is enabled and disabled by the 

TAXi_Control.unpr bit (bit <60> of the TAXi_Control register, 468 of Fig. 4g, see section V.E, 
infra). 
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Physical pages are divided for management betv^een Tapestry operating system (312 of 
Fig. 3a) and X86 operating system 306, and PFAT ISA bit 180 for the page (which is cached in 
the I-TLB.ISA bit 182) is set accordingly, Zero for Tapestry, One for X86. For all X86 pages, 
the XP bit (184 in PFAT 172, 186 in I-TLB 116) is cleared to Zero to indicate "unprotected." 
XP bit 184, 186 has no effect on Tapestry pages. 

XP bit 184, 186 behaves somevs^hat analogously to a MESI (Modified, Exclusive, Shared, 
Invalid) cache protocol. The XP "unprotected" state is roughly equivalent to the MESI 
"Exclusive" state, and means that no information from this page may be cached v^hile the page 
remains unprotected. The "protected" XP state is roughly equivalent to the MESI "Shared" state, 
and means that information from the page may be cached, but cached information must be 
purged before the page can be written. Four points of the analogy are explained in Table 2. 

Table 2 



MESI 






fetch for 
sharing 


write 


Shared 


cached 




action 1 


Exclusive 


uncached / 
exclusive 


action 2 


3 



TAXi XP protection 






fetch for 
sharing 


write 


Protected 






action 1 


Unprotected 


uncached / 
exclusive 


action 2 


3 



action 1 : discard all cached copies of the data, transition to the uncached/exclusive state 
action 2: fetch a shared/duplicate copy, and transition to the cached/shared state. 



15 A write to a MESI "Shared" cache line forces all other processors to purge the cache line, 

and the line is set to "Exclusive." Analogously, a write to an XP-protected 184, 186 page causes 
the page to be set to unprotected. These two analogous actions are designated "action 1" in 
Table 2. If ISA bit 180, 182 is One and XP bit 184, 186 is One, then this is an X86 instruction 
page that is protected. Any store to an X86 ISA page whose XP bit 184, 186 is One (protected), 

20 whether the current code is X86 native code or TAXi code, is aborted and control is passed to the 
protected exception handler. The handler marks the page unprotected by setting the page's XP 
bit 184, 186 to Zero. Any TAXi code associated with the page is discarded, and PIPM database 
602 that tracks the TAXi code is cleaned up to reflect that discarding. Then the store is retried - 
it will now succeed, because the page's XP bit 184, 186 has been cleared to Zero (unprotected). 

25 If TAXi code writes onto the X86 page of which this TAXi code is the translation, then the 
general mechanism still works - the exception handler invalidates the TAXi code that was 
running, and will retum to the converter and original X86 text instead of the TAXi code that 
executed the store. 
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A write to a "Exclusive" cache line, or to an XP-unprotected 184, 186 page, induces no 
state change. If XP bit 184, 186 is Zero (unprotected), then stores are allowed to complete. 
These two states are labeled "3" in Table 2. 

A read from a MESI "Shared" cache line proceeds without further delay, because the data 

5 in the cache are current. Analogously, converter 136 execution of an instruction from an XP- 
protected 184, 186 page proceeds without delay, because if any translated TAXi code has been 
generated from the instructions on the page, the TAXi code is current, and the profiling and 
probing mechanisms (400, 600, see sections V and VI, infra) will behave correctly. These 
analogous responses are labeled "4" in Table 2. 

10 A read from a cache line, where that cache line is held in another processor in 

"Exclusive" state, forces the cache line to be stored to memory from that other processor, and 
then the line is read into the cache of the reading processor in "Shared" state. Analogously, 
when converter 136 executes code from XP-unprotected 184, 186 page (ISA is One, representing 
X86 code, and XP bit 184, 186 is Zero, indicating unprotected), and is about to write a profile 

15 trace-packet entry, with certain additional conditions, the machine takes an "unprotected" 

exception and vectors to the corresponding handler. The handler makes the page protected and 
synchronizes that page with other processors. These analogous actions are labeled "action 2" in 
Table 2. An unprotected exception is raised when an instruction is fetched from an unprotected 
X86 page (the page's I-TLB .ISA bit 182 is One, see section II, infra, and I-TLB.XP 186 bit is 

20 Zero), and TAXi_Control.unpr 468 is One and either of the following: 

(1) a profile capture instruction is issued to start a new profile packet 

(TAXi_State.Profile_Active (482 of Fig. 4h) is Zero, TAXi_State.Profile_Request 484 
is One, and TAXi_State.Event_Code_Latch 486, 487 contains an event code for which 
"initiate packet" 418 is True in Fig, 4b), or 
25 (2) when the first instruction in a converter recipe is issued and TAXi_State.Profile_Active 

482 is One. 

The TAXi__State terms of this equation are explained in sections V.E and V.F and Figs. 4g, 4h, 
5a and 5b. 

30 The unprotected exception handler looks up the physical page address of the fetched 

instruction from the EPC.EIP (the EPC is the native exception word (instruction pointer and 
PS W) pushed onto the stack by the exception, and EPC.EIP is the instruction pointer value), or 
from a TLB fault address processor register. The interrupt service routine sets the PFAT.XP bit 
184 and I-TLB.XP bit 186 for the page to One, indicating that the page is protected. This 
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information is propagated to the other Tapestry processors and DMU (DMA monitoring unit) 
700, in a manner similar to a 'TLB shoot-down" in a shared-memory multiprocessor cache 
system. The exception handler may either abort the current profile packet (see section V.F, 
infra), or may put the machine in a context from which the profile packet can be continued. 

5 Then the exception handler returns to converter 136 to resume execution. 

When TAXi_Control.unpr (468 of Fig. 4g) is clear, then the value of the XP bit 184, 186 
is ignored: no exception is generated and TAXi software is responsible for validating the profile 
packet and setting the "Protected" page attribute. 

In an alternative embodiment, the improtected exception handler aborts the current profile 

10 packet, and enqueues the identity of the page. Later, a lazy agent, analogous to a page purifier in 
a virtual memory system, manipulates the PFAT.XP bit 184, 1-TLB.XP bit 186, and DMU 
(DMA monitoring unit) to protect the page. When execution next enters the page, the page will 
be protected, and profiling proceeds in the normal course. 

Attempts to write to a protected page (for instance, by self-modifying code, or a write to a 

15 mixed text-and-data page) will be trapped, and the page will be set unprotected again. 

Profiling is effectively disabled for unprotected pages, because an attempt to profile on an 
unprotected page, while TAXi Control.unpr 468 is One, raises an unprotected exception, and the 
unprotected exception handler either makes the page protected, or aborts the profile packet. 
Turning off profiling for unprotected pages ensures that an unprotected page will not be 

20 recognized as a hot spot, and thus not translated. Conversely, if a page cannot be protected (for 
instance, the page is not the well-behaved memory of address space zero, but rather is mapped to 
an I/O bus), then any profile packet cxirrently being collected is aborted. The implementation of 
this rule, and some limited exceptions, are discussed in section V.H, infra. 

Further details of the XP protection mechanism are discussed in VIII, infra. A second 

25 protection mechanism, for protecting pages against writes by DMA devices, is described in 
section VII, infra. 

II. Indicating the instruction set architecture (ISA) for program text 

Referring to Figs, la, lb, Ic and Id, a program is divided into regions 176, and each 

30 region has a corresponding flag 180. Flag 180 asserts 178 an ISA under which instruction 

decode unit 134, 136, 140 is to decode instructions from the corresponding region. For instance, 
the address space is divided into pages 176 (the same pages used for virtual memory paging), 
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and ISA bit 180 in a page table entry (PTE) asserts the ISA to be used for the instructions of the 
page. When instructions are fetched from a page 176 whose ISA bit 180, 182 is a Zero, the 
instructions are interpreted as Tapestry native instructions and fed 138 by ISA select 178 directly 
to pipeline 120. When instructions are fetched from a page 176 whose ISA bit 180, 182 is a One, 

5 the instructions are fed under control of ISA select 178 to Convert stage 134, 136 of the pipeline, 
which interprets instructions as Intel X86 instructions. The regions need not be contiguous, 
either in virtual memory or in physical memory - regions of X86 text can be intermingled with 
regions of native Tapestry text, on a page-by-page basis. 

A program written for one ISA can call library routines coded in either ISA. For 

10 instance, a particular program may use both a database management system and multimedia 
features. The multimedia services might be provided by libraries in optimized Tapestry native 
code. The database manager may be an off-the-shelf database system for the X86. The calling 
program, whether compiled for the X86 or for Tapestry, can readily call both libraries, and the 
combination will seamlessly cooperate. 

15 In one embodiment, ISA bit is instantiated in two places, a master copy 180 and a cached 

copy 182 for fast access. The master copy is a single bit 180 in each entry 174 in PFAT 172. 
There is one PFAT entry 174 corresponding to each physical page of the memory 118, and the 
value of the value of ISA bit 180 in a given PFAT entry 174 controls whether Tapestry processor 
100 will interpret instructions fetched from the corresponding page under the native instruction 

20 set architecture or as X86 instructions. On an I-TLB miss, the PTE from the Intel-format page 
tables is loaded into the I-TLB, as cached copy 182. The physical page frame number from the 
page table entry is used to index into PFAT 172, to find the corresponding PFAT entry 174, and 
information from the PFAT entry 174 is used to supplement the Intel-format I-TLB entry. Thus, 
by the time the bit is to be queried during an instruction fetch 110, the ISA bit 180 bit is in its 

25 natural location for such a query, I-TLB 116. Similarly, if the processor uses a unified 

instruction and data TLB, the page table and PFAT information are loaded into the appropriate 
entry in the unified TLB. 

In alternative embodiments, ISA bit 180 may be located in the address translation tables, 
whether forward-mapped or reverse-mapped. This embodiment may be more desirable in 

30 embodiments that are less constrained to implement a pre-existing fixed virtual memory 
architecture, where the designers of the computer have more control over the multiple 
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architectures to be implemented. In another ahernative, ISA bit 180, 182 may be copied as a 
datum in I-cache 112. 

When execution flows from a page of one ISA 180, 182 to a page of another (e.g., when 
the source of a control flow transfer is in one ISA and the destination is in the other), Tapestry 

5 detects the change, and takes a exception, called a "transition exception." The exception vectors 
the processor to one of two exception handlers, a Tapestry-to-X86 handler (340 of Fig. 3i) or an 
X86-to-Tapestry handler (320 of Fig, 3h), where certain state housekeeping is performed. In 
particular, the exception handler changes the ISA bit 194 in the EPC (the copy of the PSW that 
snapshots the state of the interrupted X86 process), so that the RFE (return from exception 

1 0 instruction) at the end of the transition exception handler 320, 340 will load the altered EPC.ISA 
bit 194 into the PSW. The content of the PSW.ISA bit 194 is the state variable that controls the 
actual execution of the processor 100, so that the changed ISA selection 178 takes effect when 
execution resumes. The PFAT.ISA copy 180 and I-TLB.ISA copy 182 are mere triggers for the 
exceptions. The exception mechanism allows the instructions in the old ISA to drain from the 

15 pipeline, reducing the amount of control circuitry required to effect the change to the new ISA 
mode of execution. 

Because the Tapestry and X86 architectures share a common data representation (both 
little endian, 32-bit addresses, IEEE-754 floating-point, structure member alignment rules, etc.), 
the process can resume execution in the new ISA with no change required to the data storage 
20 state of the machine. 

In an alternative embodiment, the execution of the machine is controlled by the I- 
TLB.ISA copy of the bit ISA bit 194, and the PSW.ISA copy 190 is a history bit rather than a 
control bit. When execution flows onto a page whose ISA bit 180, 182 does not match the ISA 
180, 182 of the previous page, at the choice of the implementer, the machine may either take a 
25 transition exception, or "change gears" without taking a transition exception. 

There is a "page properties enable" bit in one of the processor control registers. On 
system power-on, this bit is Zero, disabling the page properties. In this state, the PSW.ISA bit is 
manipulated by software to turn converter 136 on and off, and transition and probe exceptions 
are disabled. As system initialization completes, the bit is set to One, and the PFAT and TLB 
30 copies of the ISA bit control system behavior as described supra. 
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III. Saving Tapestry processor context in association with an X86 thread 
A. Overview 

Referring to Figs. 3a-3f, the ability to run programs in either of two instruction sets opens 
the possibility that a single program might be coded in both instruction sets. As shown in Fig. 

5 3b, the Tapestry system provides transparent calls from caller to callee, without either knowing 
the ISA of the other, without either caller or callee being specially coded to work with the other. 
As shovm in Fig. 3c, an X86 caller 304 might make a call to a callee subprogram, without being 
constrained to work with only callees coded in the X86 instruction set or the native Tapestry 
RISC instruction set 308. If the callee is coded in the X86 instruction set, the call will execute as 

1 0 a normal call. If the callee 308 is coded in the native Tapestry instruction set, then Tapestry 
processor 100 will take a transition exception 384 on entry to the callee 308, and another 
transition exception 386 on returning from the Tapestry callee 308 to the X86 caller 304. These 
transition exceptions 384, 386 and their handlers (320 of Fig. 3h and 340 of Fig. 31) convert the 
machine state from the context established by the X86 caller to the context expected by the 

1 5 Tapestry callee 308. 

Referring to Figs, 3c-3f, analogous transition exceptions 384, 386 and handlers 320, 340 
provide the connection between an X86 caller and its callees (Fig. 3c), a native Tapestry caller 
and its callees (Fig. 3d), between an X86 callee and its callers (Fig. 3e), and between a native 
Tapestry callee its callers (Fig. 3f), and provides independence between the ISA of each caller- 

20 callee pair. 

Referring to Figs. 3a and 31 and to Table 1, X86 threads (e.g., 302, 304) managed by X86 
operating system 306, carry the normal X86 context, including the X86 registers, as represented 
in the low-order halves of r32-r55, the EFLAGS bits that affect execution of X86 instructions, 
the current segment registers, etc. In addition, if an X86 thread 302, 304 calls native Tapestry 
25 libraries 308, X86 thread 302, 304 may embody a good deal of extended context, the portion of 
the Tapestry processor context beyond the content of the X86 architecture. A thread's extended 
context may include the various Tapestry processor registers, general registers rl-r31 and r56- 
r63, and the high-order halves of r32-r55 (see Table 1), the current value of ISA bit 194 (and in 
the embodiment of section IV, infra, the current value of XP / calling convention bit 196 and 
30 semantic context field 206). 

The Tapestry system manages an entire virtual X86 310, with all of its processes and 
threads, e.g., 302, 304, as a single Tapestry process 311. Tapestry operating system 312 can use 
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conventional techniques for saving and restoring processor context, including ISA bit 194 of 
PSW 190, on context switches between Tapestry processes 311, 314. However, for threads 302, 
304 managed by an off-the-shelf X86 operating system 306 (such as Microsoft Windows or IBM 
OS/2) within virtual X86 process 311, the Tapestry system performs some additional 
housekeeping on entry and exit to virtual X86 310, in order to save and restore the extended 
context, and to maintain the association between extended context information and threads 302, 
304 managed by X86 operating system 306. (Recall that Tapestry emulation manager 316 runs 
beneath X86 operating system 306, and is therefore unaware of entities managed by X86 
operating system 306, such as processes and threads 302, 304.) 

Figs. 3a-3o describe the mechanism used to save and restore the full context of an X86 
thread 304 (that is, a thread that is under management of X86 operating system 306, and thus 
invisible to Tapestry operating system 312) that is currently using Tapestry extended resources. 
In overview, this mechanism snapshots the full extended context into a memory location 355 that 
is architecturally invisible to virtual X86 310. A correspondence between the stored context 
memory location 355 and its X86 thread 304 is maintained by Tapestry operating system 312 
and X86 emulator 316 in a manner that that does not require cooperation of X86 operating 
system 306, so that the extended context will be restored when X86 operating system 306 
resumes X86 thread 304, even if X86 operating system 306 performs several context switches 
among X86 threads 302 before the interrupted X86 thread 304 resumes. The X86 emulator 316 
or Tapestry operating system 312 briefly gains control at each transition from X86 to Tapestry or 
back, including entries to and returns from X86 operating system 306, to save the extended 
context and restore it at the appropriate time. 

The interaction between hardware converter 136 and software emulator 316 is elaborated 
in section IX in general, and more particularly in sections IX.A.2 and IX.B.6, infra. 

The description of the embodiment of Figs. 3g-3k, focuses on crossings from one ISA to 
the other under defined circumstances (subprogram calls and returns and interrupts), rather than 
the fiilly general case of allowing transitions on any arbitrary transfer (conditional jumps and the 
like). Because there is always a Tapestry source or destination at any cross-ISA transfer, and the 
number of sites at which such a transfer can occur is relatively limited, the Tapestry side of each 
transition site can be annotated with information that indicates the steps to take to convert the 
machine state from that established in the source context to that expected in the destination 
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context. In the alternative embodiment of section IV, the hardware supplements this software 
annotation, to allow the fully general ISA crossing. 

The interaction between the native Tapestry and X86 environments is effected by the 
cooperation of an X86-to-Tapestry transition exception handler (320 of Fig. 3h), a Tapestry-to- 
5 X86 transition exception handler (340 of Fig. 3i), interrupt/exception handler (350 of Fig. 3j) of 
Tapestry operating system 312, and X86 emulator 316 (the software that emulates the portions of 
the X86 behavior that are not conveniently executed in converter hardware 136). 

Because all native Tapestry instructions are naturally aligned to a 0 mod 4 boundary, the 
two low-order bits <1 :0> of a Tapestry instruction address are always known to be Zero. Thus, 

10 emulator 316, and exception handlers 320, 340, 350 of Tapestry operating system 312, can pass 
information to each other in bits <1 :0> of a Tapestry instruction address. To consider an 
example, the return address of a call from native Tapestry code, or the resume address for an 
interrupt of native code, will necessarily have two Zeros in its least significant bits. The 
component that gains control (either Tapestry-to-X86 transition handler 340 or Tapestry 

1 5 operating system 312) stores context information in these two low-order bits by setting them as 
shown in Table 3: 



Table 3 


00 


default case, where X86 caller set no value of these bits - by elimination, this means 
the case of calling a native Tapestry subprogram 


01 


resuming an X86 thread suspended in a native Tapestry subprogram 


10 


returning from an X86 callee to a native Tapestry caller, result already in register(s) 


11 


returning from an X86 callee to a native Tapestry caller, where the fiinction result is in 
memory as specified in the X86 calling convention, and is to be copied into registers as 
specified by the Tapestry calling convention. 



Then, when control is to be returned to a Tapestry caller or to interrupted Tapestry native code, 
20 X86-to-Tapestry transition handler 320 uses these two bits to determine the context of the caller 
that is to be restored, and restores these two bits to Zero to return control to the correct address, 

A second information store is the XD register (register R15 of Table 1). The Tapestry 
calling convention (see section IILB, infra) reserves this register to communicate state 
information, and to provide a description of a mapping fi*om a machine state imder the X86 
25 calling convention to a semantically-equivalent machine context under the Tapestry convention, 
or vice-versa. The Tapestry cross-ISA calling convention specifies that a caller, when about to 
call a callee subprogram that may be coded in X86 instructions, sets the XD register to a value 
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that describes the caller's argument list. Similarly, when a Tapestry callee is about to return to 
what may be an X86 caller, the calling convention requires the callee to set XD to a value that 
describes the return value returned by the function. From that description, software can 
determine how that return value should be converted for acceptance by the callee under the X86 

5 calling convention. In each case, the XD value set by the Tapestry code is non-zero. Finally, 
X86-to-Tapestry transition handler 320 sets XD to zero to indicate to the Tapestry destination 
that the argument list is passed according to the X86 calling convention. As will be described 
further infra, each Tapestry subprogram has a prolog that interprets the XD value coming in, to 
convert an X86 calling convention argument list into a Tapestry calling convention argument list 

1 0 (if the XD value is zero), and Tapestry-to-X86 exception handler 340 is programmed to interpret 
the XD value retixmed from a Tapestry function to convert the function return value into X86 
form. 

The Tapestry calling convention requires a callee to preserve the caller's stack depth. 
The X86 convention does not enforce such a requirement. X86-to-Tapestry transition handler 

1 5 320 and Tapestry-to-X86 transition handler 340 cooperate to enforce this discipline on X86 

callees. When Tapestry-to-X86 transition handler 340 detects a call to an X86 callee, transition 
handler 340 records (343 of Fig. 3i) the stack depth in register ESI (R54 of Table 1). ESI is half- 
preserved by the X86 calling convention and fully preserved by the native convention. On 
return, X86-to-Tapestry transition handler 320 copies ESI back to SP, thereby restoring the 

20 original stack depth. This has the desired side-effect of deallocating any 32 byte hidden 
temporary created (344 of Fig. 3i) on the stack by Tapestry-to-X86 transition handler 340. 

B. Subprogram Prologs 

A "calling convention" is simply an agreement among software components for how data 
are to be passed from one component to the next. If all data were stored according to the same 

25 conventions in both the native RISC architecture and the emulated CISC architecture, then a 
transition between two ISA environments would be relatively easy. But they do not. For 
instance, the X86 calling convention is largely defined by the X86 architecture. Subroutine 
arguments are passed on a memory stack. A special PUSH instruction pushes arguments onto 
the stack before a subprogram call, a CALL instruction transfers control and saves the return 

30 linkage location on the stack, and a special RET (return) instruction returns control to the caller 
and pops the callee' s data from the stack. Inside the callee program, the arguments are 
referenced at known offsets off the stack pointer. On the other hand, the Tapestry calling 
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convention, like most RISC calling conventions, is defined by agreement among software 
producers (compilers and assembly language programmers). For instance, all Tapestry software 
producers agree that the first subprogram argument will be passed in register 32, the second in 
register 33, the third in register 34, and so on. 

5 Referring to Fig. 3g, any subprogram compiled by the Tapestry compiler that can 

potentially be called from an X86 caller is provided with both a GENERAL entry point 317 and 
a specialized NATIVE entry point 318. GENERAL entry point 317 provides for the fixll 
generality of being called by either an X86 or a Tapestry caller, and interprets 319 the value in 
the XD register (R15 of Table 1) to ensure that its parameter list conforms to the Tapestry calling 

10 convention before control reaches the body of the subprogram. GENERAL entry point 317 also 
stores some information in a return transition argument area (RXA, 326 of Fig. 3h) of the stack 
that may be usefiil during return to an X86 caller, including the current value of the stack pointer, 
and the address of a hidden memory temp in which large fimction retum values might be stored. 
NATIVE entry point 318 can only be used by Tapestry callers invoking the subprogram by a 

1 5 direct call (without going through a pointer, virtual fimction, or the like), and provides for a 

more-efficient linkage; the only complexities addressed by NATIVE entry point 318 are varargs 
argument lists, or argument lists that do not fit in the sixteen parameter registers P0-P15 (R32- 
R47 of Table 1). The value of GENERAL entry point 317 is returned by any operation that takes 
the address of the subprogram. 

20 

C. X86-to-Tapestry transition handler 

Referring to Fig. 3h, X86-to-Tapestry transition handler 320 is entered under three 
conditions: (1) when code in the X86 ISA calls native Tapestry code, (2) when an X86 callee 
subprogram returns to a native Tapestry caller, and (3) when X86 operating system 306 resumes 
25 a thread 304 that was interrupted by an asynchronous external interrupt while executing native 
Tapestry code. 

X86-to-Tapestry transition handler 320 dispatches 321 on the two-low order bits of the 
destination address, as obtained in EPC.EIP, to code to handle each of these conditions. Recall 
that these two bits were set to values reflected in Table 3, supra, 
30 If those two low-order bits EPC<01 :00> are "00," case 322, this indicates that this 

transition is a CALL from an X86 caller to a Tapestry callee (typically a Tapestry native 
replacement for a library routine that that caller expected to be coded in X86 binary code). 
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Transition handler 320 pops 323 the return address from the memory stack into the linkage 
register LR (register R6 of Table 1). Pop 323 leaves SP (the stack pointer, register R52 of Table 
1) pointing at the first argument of the X86 caller's argument list. This SP value is copied 324 
into the AP register (the argument pointer, register R5 of Table 1). SP is decremented 326 by 
5 eight, to allocate space for a return transition argument area (the return transition argument area 
may be used by the GENERAL entry point (317 of Fig. 3g) of the callee), and then the SP is 
rounded down 327 to 32-byte alignment. Finally, XD is set 328 to Zero to inform the callee's 
GENERAL entry point 317 that this call is arriving with the machine configured according to the 
X86 calling convention. 

1 0 If the two low-order bits of the return address EPC<0 1 :00> are " 1 0'' or " 11 cases 329 

and 332, this indicates a return from an X86 callee to a Tapestry caller. These values were 
previously stored into EPC<01:00> by Tapestry-to-X86 transition handler 340 at the time the 
X86 callee was called, according to the nature of the function return result expected. 

Low-order bits of "1 1," case 329, indicate that the X86 callee created a large function 

15 result {e.g., a 16-byte struct) in memory, as specified by the X86 calling convention. In this case, 
transition handler 320 loads 330 the function result into registers RV0-RV3 (registers R48-R51 - 
see Table 1) as specified by the Tapestry calling convention. Low-order bits of "10," case 332, 
indicate that the function result is already in registers (either integer or FP). 

In the register-retum-value "10" case 332, X86-to-Tapestry transition handler 320 

20 performs two register-based conversions to move the function return value from its X86 home to 
its Tapestry home. First, transition handler 320 converts the X86's representation of an integer 
result (least significant 32 bits in EAX, most significant 32 bits in EDX) into the native 
convention's representation, 64 bits in RVO (R48 of Table 1). Second, transition handler 320 
converts 334 the X86's 80-bit value at the top of the floating-point stack into the native 

25 convention's 64-bit representation in RVDP (the register in which double-precision floating- 
point results are returned, R31 of Table 1). 

The conversion for 64-bit to 80-bit floating-point is one example of a change in bit 
representation (as opposed to a copy from one location to another of an identical bit pattem) that 
may be used to convert the process context fi'om its source mode to a semantically-equivalent 

30 form in its destination mode. For instance, other conversions could involve changing strings 

from an ASCII representation to EBCDIC or vice-versa, changing floating-point from IBM base 
16 format to Digital's proprietary floating-point format or an IEEE format or another floating- 
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point format, from single precision to double, integers from big-endian to little-endian or vice- 
versa. The type of conversion required will vary depending on the characteristics of the native 
and non-native architectures implemented. 

In the "01" case 370 of resuming an X86 thread suspended during a call out to a native 
5 Tapestry subprogram, transition handler 320 locates the relevant saved context, confirms that it 
has not been corrupted, and restores it (including the true native address in the interrupted native 
Tapestry subprogram). The operation of case 370 will be described in further detail in sections 
IILF andIILG,z>7>a. 

After the case-by-case processing 322, 329, 332, 370, the two low-order bits of return 
10 address in EPC<1 :0> (the error PC) are reset 336 to "00" to avoid a native misaligned I-fetch 
fauh. At the end of cases 329 and 332, Register ESI (R54 of Table 1) is copied 337 to SP, in 
order to return to the stack depth at the time of the original call. An RFE instruction 338 resumes 
the interrupted program, in this case, at the target of the ISA-crossing control transfer. 

15 D. Tapestry-to-X86 transition handler 

Referring to Fig. 3i, Tapestry-to-X86 handler 340 is entered under two conditions: (1) a 

native Tapestry caller calls an X86 callee, or (2) a native Tapestry callee returns to an X86 caller. 
In either case, the four low-order bits XD<3:0> (the transfer descriptor register, R15 of Table 1) 
were set by the Tapestry code to indicate 341 the steps to take to convert machine context from 

20 the Tapestry calling convention to the X86 convention. 

If the four low-order bits XD<03:00> direct 341 a return from a Tapestry callee to an 
X86 caller, the selected logic 342 copies any function return value from its Tapestry home to the 
location specified by the X86 calling convention. For instance, XD may specify that a 64-bit 
scalar integer result returned in RVO is to be returned as a scalar in EAX or in the EDX:EAX 

25 register pair, that a double-precision floating-point result is to be copied from RVO to the top of 
the X86 floating-point stack as an 80-bit extended precision value, or that a large return value 
being returned in RV0-RV3 (R48-R51 of Table 1) is to be copied to the memory location 
specified by original X86 caller and saved in the RXA. The stack depth is restored using the 
stack cutback value previously saved in the RXA by the GENERAL entry point prolog 317. 

30 If a Tapestry caller expects a result in registers but understands under the X86 calling 

convention that an X86 function with the same prototype would return the result via the RVA 
mechanism (retuming a return value in a memory location pointed to by a hidden first argument 
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in the argument list), the Tapestry caller sets XD<3:0> to request the following mechanism from 
handler 340. The caller's stack pointer is copied 343 to the ESI register (R54 of Table 1) to 
ensure that the stack depth can be restored on return. A naturally-aligned 32-byte temporary is 
allocated 344 on the stack and the address of that temporary is used as the RVA (R3 1 of Table 1) 

5 value. Bits LR<1 :0> are set 345 to "1 1" to request that X86-to-Tapestry transition handler 320 
load 32 bytes from the allocated buffer into RV0-RV3 (R48-R51 of Table 1) when the X86 
callee returns to the Tapestry caller. 

For calls that will not use the RVA mechanism (for instance, the callee will return a 
scalar integer or floating-point value, or no value at all), Tapestry-to-X86 transition handler 340 

10 takes the following actions. The caller's stack pointer is copied 343 to the ESI register (R54 of 
Table 1) to ensure that the stack depth can be restored on return. Bits LR<1 :0> are set 346 to 
"10" as a flag to X86-to-Tapestry transition handler 320, 332 on retuming to the native caller. 
For calls, handler 340 interprets 347 the remainder of XD to copy the argument list from the 
registers of the Tapestry calling convention to the memory locations of the X86 convention. The 

15 retum address (LR) is pushed onto the stack. 

For returns from Tapestry callees to X86 callers, the X86 floating-point stack and control 
words are established. 

Tapestry-to-X86 transition handler 340 concludes by establishing 348 other aspects of the 
X86 execution environment, for instance, setting up context for emulator 316 and profiler 400. 
20 An RFE instruction 349 returns control to the destination of the transfer in the X86 routine. 

E. Handling ISA crossings on interrupts or exceptions in the Tapestry operating 
system 

Referring to Fig. 3j in association with Figs. 3a and 31, most interrupts and exceptions 
25 pass through a single handler 350 in Tapestry operating system 312. At this point, a number of 
housekeeping functions are performed to coordinate Tapestry operating system 312, X86 
operating system 306, processes and threads 302, 304, 311, 314 managed by the two operating 
systems 306, 312, and the data configuration of those processes and threads that may need to be 
altered to pass from one calling convention to the other. 
30 A number of interrupts and exceptions are skimmed off and handled by code not depicted 

in Fig. 3j. This includes all interrupts directed to something outside virtual X86 310, including 
all synchronous exceptions raised in other Tapestry processes, the interrupts that drive 
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housekeeping functions of the Tapestry operating system 312 itself (e.g., a timer interrupt), and 
exceptions raised by a Tapestry native process 314 (a process under the management of Tapestry 
operating system 312). Process-directed interrupts handled outside Fig, 3j include asynchronous 
interrupts, the interrupts not necessarily raised by the currently-executing process (e.g., cross- 
5 processor synchronization interrupts). These interrupts are serviced in the conventional manner 
in Tapestry operating system 312: the full Tapestry context of the thread is saved, the interrupt is 
serviced, and Tapestry operating system 312 selects a thread to resume. 

Thus, by the time execution reaches the code shov^n in Fig. 3j, the interrupt is guaranteed 
to be directed to something v^ithin virtual X86 310 (for instance, a disk completion interrupt that 
10 unblocks an X86 thread 302, 304, or a page fauh, floating-point exception, or an INT software 
interrupt instruction, raised by an X86 thread 302, 304), and that this interrupt must be reflected 
from the Tapestry handlers to the virtual X86 310, probably for handling by X86 operating 
system 306. 

Once X86 operating system 306 gains control, there is a possibility that X86 operating 

15 system 306 will context switch among the X86 processes 302, 304. There are two classes of 
cases to handle. The first class embraces cases 351, 353, and 354, as discussed further infra. In 
this class of cases, the interrupted process has only X86 state that is relevant to save. Thus, the 
task of maintaining the association between context and thread can be handed to the X86 
operating system 306: the context switch mechanism of that operating system 306 will perform 

20 in the conventional manner, and maintain the association between context and process. On the 
other hand, if the process has extended context that must be saved and associated with the 
current machine context (e.g., extended context in a Tapestry library called on behalf of a 
process managed by X86 OS), then a more complex management mechanism must be employed, 
as discussed infra in connection with case 360. 

25 If the interrupted thread was executing in converter 136, as indicated by ISA bit 194 of 

the EPC, then the exception is handled by case 351. Because the interrupted thread is executing 
X86 code entirely within the virtual X86, the tasks of saving thread context, servicing the 
interrupt, and selecting and resuming a thread can be left entirely to X86 operating system 306. 
Thus, Tapestry operating system 306 calls the "deliver interrupt" routine (352 of Fig. 3a) in X86 

30 emulator 316 to reflect the interrupt to virtual X86 310. The X86 operating system 306 will 
receive the interrupt and service it in the conventional manner. 
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If an interrupt is directed to something within virtual X86 310, while TAXi code (a 
translated native version of a "hot spot" within an X86 program, see section I.D, supra, as 
indicated by the TAXi_Active bit 198 of the EPC) was running, then the interrupt is handled by 
case 353. Execution is rolled back to an X86 instruction boundary. At an X86 instruction 

5 boundary, all Tapestry extended context external to the X86 310 is dead, and a relatively simple 
correspondence between semantically-equivalent Tapestry and X86 machine states can be 
established. Tapestry execution may be abandoned - after the interrupt is delivered, execution 
may resume in converter 136. Then, if the interrupt was an asynchronous external interrupt, 
TAXi will deliver the appropriate X86 interrupt to the virtual X86 supplying the reconstructed 

1 0 X86 machine state, and the interrupt will be handled by X86 operating system 306 in the 
conventional manner. Else, the rollback was induced by a synchronous event, so TAXi will 
resume execution in converter 136, and the exception will be re-triggered, with EPC .ISA 194 
indicating X86, and the exception will be handled by case 351. 

If the interrupted thread was executing in X86 emulator 316, as indicated by the EM86 

15 bit of the EPC, the interrupt is handled by case 354. This might occur, for instance, when a high- 
priority X86 interrupt interrupts X86 emulator 316 while emulating a complex instruction {e.g, 
far call through a gate) or servicing a low-priority interrupt. The interrupt is delivered to 
emulator 316, which handles the interrupt. Emulator 316 is written using re-entrant coding to 
permit re-entrant self-interruption during long-running routines. 

20 Case 360 covers the case where the interrupt or exception is directed to something within 

virtual X86 310, and the current thread 304, though an X86 thread managed by X86 operating 
system 306, is currently executing Tapestry code 308, For instance, an X86 program may be 
calling a native Tapestry library. Here, the interrupt or exception is to be serviced by X86 
operating system 306, but the thread currently depends on Tapestry extended context. In such a 

25 case, X86 operating system 306 may perform a context switch of the X86 context, and the full 
Tapestry context will have to be restored when this thread is eventually resumed. However, X86 
operating system 306 has no knowledge of (nor indeed has it addressability to) any Tapestry 
extended context in order to save it, let alone restore it. Thus, case 360 takes steps to associate 
the current Tapestry context with the X86 thread 304, so that the fiall context will be re- 

30 associated (by code 370 of Fig. 3h) with thread 304 when X86 operating system 306 resumes the 
thread's execution. 
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Referring briefly to Fig. 3k, during system initialization, the Tapestry system reserves a 
certain amount of nonpageable storage to use as "save slots" 355 for saving Tapestry extended 
context to handle case 360. The save slot reserved memory is inaccessible to virtual X86 310. 
Each save slot 355 has space 356 to hold a full Tapestry context snapshot. Each save slot 355 is 

5 assigned a number 357 for identification, and a timestamp 358 indicating the time at which the 
contents of the save slot were stored. Full/empty flag 359 indicates whether the save slot 
contents are currently valid or not. In an alternative embodiment, a timestamp 358 of zero 
indicates that the slot is unused. 

Returning to Fig. 3j, case 360 is handled as follows. A save slot 355 is allocated 361 

10 from among those currently free, and the slot is marked as in use 359. If no save slot is free, then 
the save slot with the oldest time stamp 358 is assumed to have been stranded, and is forcibly 
reclaimed for recycling. Recall that the save slots 355 are allocated from non-paged storage, so 
that no page fault can result in the following stores to the save slot. The entire Tapestry context, 
including the X86 context and the extended context, and the EIP (the exception instruction 

15 pointer, the address of the interrupted instruction) is saved 362 into the context space 356 of 

allocated save slot 355. The two low-order bits of the EIP (the address at which the X86 IP was 
interrupted) are overwritten 363 with the value "01," as a signal to X86-to-Tapestry transition 
handler 320, 370. The EIP is otherwise left intact, so that execution will resume at the 
interrupted point. (Recall that case 360 is only entered when the machine was executing native 

20 Tapestry code. Thus, the two low-order bits of the EIP v^U arrive at the beginning of handler 
350 with the value "00," and no information is lost by overwriting them.) The current 64-bit 
timestamp is loaded 364 into the EBX:ECX register pair (the low order halves of registers R49 
and R51, see Table 1) and redundantly into ESLEDI (the low order halves of registers R54-R55) 
and the timestamp member (358 of Fig, 3k) of save slot 355. The 32-bit save slot number 357 of 

25 the allocated save slot 355 is loaded 365 into the X86 EAX register (the low order half of register 
R48) and redundantly in EDX (the low order half of register R50). Now that all of the Tapestry 
extended context is stored in the save slot 355, interrupt handler 350 of Tapestry operating 
system 312 now transfers control to the "deliver interrupt" entry point 352 of X86 emulator 316. 
X86 operating system 306 is invoked to handle the interrupt. 

30 Interrupt delivery raises a pending interrupt for the virtual X86 310. The interrupt will be 

accepted by X86 emulator 316 when the X86 interrupt accept priority is sufficiently high. X86 
emulator 316 completes delivery of the interrupt or exception to the X86 by emulating the X86 
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hardware response to an interrupt or exception: pushing an exception frame on the stack 
(including the interrupted X86 IP, with bits <1 :0> as ahered at step 363 stored in EPC), and 
vectoring control to the appropriate X86 interrupt handler. 

Execution now enters the X86 ISR (interrupt service routine), typically in X86 operating 

5 system 306 kernel, at the ISR vectored by the exception. The X86 ISR may be an off-the-shelf 
routine, completely unmodified and conventional. A typical X86 ISR begins by saving the X86 
context (the portion not already in the exception frame - typically the process' registers, the 
thread ID, and the like) on the stack. The ISR typically diagnoses the interrupting condition, 
services it, and dismisses the interrupt. The ISR has full access to the X86 context. X86 

10 operating system 306 will not examine or rely on the contents of the X86 processor context; the 
context will be treated as a "black box" to be saved and resumed as a whole. As part of servicing 
the interrupt, the interrupted thread is either terminated, put to sleep, or chosen to be resumed. In 
any case, the ISR chooses a thread to resume, and restores the X86 context of that thread. The 
ISR typically retums control to the selected thread either via an X86 IRET instruction or an X86 

1 5 JUMP. In either case, the address at which the thread is to be resumed is the address previously 
pushed in an X86 exception frame when the to-be-resumed thread was interrupted. The thread 
resumed by X86 operating system 306 may be either interrupted thread 304 or another X86 
thread 302. 

20 F. Resuming Tapestry execution from the X86 operating system 

Referring again to Fig. 3h, X86 operating system 306 eventually resumes interrupted 

thread 304, after a case 360 interrupt, at the point of interruption. X86 operating system 306 
assumes that the thread is coded in X86 instructions. The first instruction fetch will be from a 
Tapestry page (recall that execution enters case 360 only when interrupted thread 304 was 

25 executing Tapestry native code). This will cause an X86-to-Tapestry transition exception, which 
will vector to X86-to-Tapestry transition handler 320. Because the low-order two bits of the PC 
were set (step 363 of Fig. 3j) to "01," control dispatches 321 to case "01" 370. 

In step 371, the save slot numbers in the X86 EAX and EDX registers are cross-checked 
(recall that the save slot number was stored in these registers by step 365 of Fig. 3j), and the 

30 timestamp stored 362 in EBX:ECX is cross-checked with the timestamp stored in ESI:EDL If 
either of these cross-checks 371 fails, indicating that the contents of the registers was corrupted, 
an error recovery routine is invoked 372. This error routine may simply kill the corrupted thread, 
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or it may bring the whole TAXi system down, at the implementer's option. If the time stamps 
pass validation, the timestamp from the EBX:ECX register pair is squirreled away 373 in a 64-bit 
exception handler temporary register that will not be overwritten during restoration of the full 
native context. The contents of register EAX is used as a save slot number to locate 374 the save 

5 slot 355 in which the Tapestry context is stored 362. The entire Tapestry native context is 
restored 375 from the located save slot 355, including restoration of the values of all X86 
registers. Restore 375 also restores the two low-order bits EPC<1 :0> to Zero. The save slot's 
timestamp 358 is cross-checked 376 against the timestamp squirreled away 373 in the temporary 
register. If a mismatch of the two timestamps indicates that the save slot was corrupted, then an 

10 error recovery routine is invoked 377. The save slot is now empty, and is marked 378 as free, 
either by clearing full/empty flag 359 or by setting its timestamp 358 to zero. Execution is 
resumed at the EPC.EIP value by RFE instruction 338, in the Tapestry code at the point 
following the interrupt. 

Referring again to Fig. 3k, in an alternative embodiment, save slots 355 are maintained in 

15 a variation of a queue: hopefully-empty save slots to be filled are always allocated from the head 
379a of the queue, full save slots to be emptied may be unlinked from the middle of the queue, 
and save slots may be entered into the queue at either the head 379a or tail 379b, as described 
infra. A double-linked list of queue entries is maintained by links 379c. At step 361, a save slot 
is allocated from the head 379a of the allocation queue. After step 365, the filled save slot 355 is 

20 enqueued at tail 379b of the save slot queue. At step 377, the emptied save slot 355 is queued at 
the head 379a of the queue. 

This ahemative head-and-tail queuing protocol 361, 379a, 379b, 379c, 375 for save slots 
355 has the following effects. The queue remains sorted into two partitions. The portion toward 
head 379a accumulates all save slots 355 known to be free. The portion toward the tail 379b 

25 holds all slots thought to be busy, in least-recently-used order. Over time, all stale slots (those 
thought to be busy but whose threads have disappeared) will accumulate at the boundary 
between the two partitions, because any time a slot with a timestamp older than that of a stale 
slot is resumed, the emptied slot is removed from the busy tail partition is moved to the fi^ee head 
partition. Normally, allocations will occur by intensively recycling the most recently freed slots 

30 at the head of the free partition while truly busy slots will cluster at the tail of the busy partition. 
When all known-free save slots 355 are exhausted and an apparently-busy save slot 355 is 
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overwritten, the busy save slots 355 will be selected in least recently used to most recently 
busied. 

In an alternative embodiment, a native Tapestry process would be allowed to call into an 
X86 library 308. Exceptions raised in the X86 code would be serviced by Tapestry operating 
5 system 312, filtered out in handler 350 of Fig. 3j before the decision point reaches the beginning 
of the code shown in Fig. 3j. 

G. An example 

Referring to Fig. 3m in conjunction with Figs. 3a, 3g, 3h, 3i, 31 and 3n, consider an 

10 example of a call by an X86 caller thread 304 to a Tapestry callee library 308, an interrupt 388 in 
the library that is serviced by X86 operating system 306, a context switch to another X86 thread 
302 and a resumption of Tapestry callee 308, and a return to the X86 caller 304. 

Tapestry library 308 is mapped 382 into a 32-bit flat address space 380. From the point 
of view of X86 caller thread 304, this is the process' address space. From the point of view of 

15 the Tapestry machine and operating system 312, the 32-bit address space is simply an address 
space that is mapped through page tables (170 of Figs, la and Id), and whose contents and 
meaning are left entirely to the management of X86 operating system 306. 

Initially, thread 304 is executing on virtual X86 310. Thread 304 executes an X86 CALL 
instruction 383, seeking a library service. The binary code for thread 304 is conventional X86 

20 code, not specially compiled for use in a Tapestry system. CALL instruction 383 transfers 

control (arrow ®) to the entry point of library 308. This is the GENERAL entry point (317 of 
Fig. 3g) for a Tapestry-binary replacement for the library. Fetching the first instruction from the 
entry preamble 317, 319 for Tapestry native library routine 308, induces a change from X86 ISA 
to Tapestry ISA. Processor 100 takes a transition exception 384, and vectors (arrow (D) to X86- 

25 to-Tapestry transition handler (320 of Fig. 3h), Because all Tapestry instructions are aligned to a 
0 mod 4 boundary, the two low-order bits of the interrupt address are "00." Accordingly, 
transition handler 320 dispatches 321 to the "00" case 322 to establish the preconditions for 
execution in the Tapestry context (32-byte aligned stack, etc.). At the end of transition handler 
320, execution resumes 338 (arrow ®) at GENERAL entry point 317. GENERAL entry point 

30 317 begins by executing the X86 preamble (319 of Fig. 3g), which copies the parameter Ust into 
the P0-P15 parameter registers, and execution of the body of Tapestry library routine 308 begins. 
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Assume that Tapestry library routine 308 runs to completion without an interrupt or call 
back to X86 code. 

When Tapestry library routine 308 completes 385, routine 308 loads a value describing 
the form of its return value into XD register (R15 of Table 1), This value will indicate a retum 

5 value in RVO, RVFP, or a memory location, as appropriate. Routine 308 concludes with a 
Tapestry JALR instruction to retum (arrow ®). As the first instruction is fetched from X86 
caller thread 304, a transition 386 from Tapestry ISA to X86 ISA is recognized, and control 
vectors (arrow (D) to Tapestry-to-X86 transition handler (340 of Fig. 3i). Transition handler 
dispatches 341 on the value of XD<03:00> to one of the retum cases 342, which copies the 

1 0 retum value from its Tapestry home to its home under the X86 calling convention. When 

transition handler 340 completes, it returns control (RFE instmction 349 of Fig. 3i, arrow ® of 
Figs. 3a, 31 and 3m) to the instmction in thread 304 following the initial CALL 383. 

Referring now to Fig. 3n in conjunction with Figs. 3a, 3h, 3j and 31, assume that an 
external asynchronous interrapt 388 occurred midway through the execution of Tapestry library 

1 5 routine 308. To establish the example, assume that the intermpt is a disk-completion intermpt 
that unblocks a second, higher-priority X86 thread 302. The intermpt vectors (arrow (Z)) to the 
intermpt/exception handler (350 of Fig. 3j) of Tapestry operating system 312. After 
disqualifying cases 351, 353, 354, intermpt handler 350 selects case 360. The full processor 
context is saved 362 in a save slot 355, the two low-order bits EIP<01 :00> are overwritten 363 

20 with "01," as described in Table 3, and the save slot number and timestamp information are 

loaded 364, 365 into the X86 registers. The interrupt handler 360 delivers the intermpt (369 of 
Fig. 3j) to the intermpt entry point 352 of X86 emulator 316 (arrow (D). X86 emulator 316 
passes control to X86 operating system 306 (arrow (D). X86 operating system 306 services the 
intermpt in the conventional manner. However, the context that X86 operating system 306 saves 

25 for thread 304 is the collection of timestamp and save slot number information with the EIP 
intact except for its two low-order bits, cobbled up by step 363 of Tapestry exception handler 
360 to conform to Table 3. As assumed earlier in this paragraph, X86 operating system 306 
selects thread 302 to be resumed (arrow ®). 



30 back to X86 operating system 306, for instance because its time slice expires, it issues a new disk 
request, or the like. Assume that the X86 operating system's scheduler now selects thread 304 to 
be resumed. The context restored by X86 operating system 306 is the timestamp and save slot 



After X86 thread 302 has executed for a time, it eventually cedes control (arrow 
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number "context" cobbled up by exception handler 360. The EIP of this restored context points 
to the instruction following the interrupted 388 instruction, with "01" in the two low-order bits. 
X86 operating system 306 executes an IRET instruction to resume execution at this restored 
context (arrow (l^). This instruction fetch will recognize the transition 389 from the X86 ISA 
5 of X86 operating system 306 to the Tapestry ISA of Tapestry library 308, and will vector (arrow 
(jj)) to X86-to-Tapestry transition handler 320 (Fig. 3h). Transition handler 320 dispatches 321 
on the two low-order bits of the EIP address to case 370. The code of case 370 looks in the X86 
registers to find the address of the save slot 355 corresponding to the process to be resumed. The 
content of the X86 registers and found save slot 355 are validated 371, 374, 376 by comparing 
10 the redundantly-stored timestamps and save slot numbers against each other. The content of 
save slot 355 restores 375 the full Tapestry processor context. Transition handler 320 resumes 
378 execution of the Tapestry library routine 308 (arrow (T^ ) at the point of the original 
external interrupt 388. 

Referring to Fig. 3o in conjunction with Figs. 3a, 3h, 3j and 31, consider the case of a call 

15 from a Tapestry native caller 391 to an X86 callee 392. (Recall from the discussion of Fig. 3b 
that neither is specially coded to be tailored to this scenario - the X86 callee was generated by a 
conventional X86 compiler, and the Tapestry caller 391 is coded to work equally well whether 
the callee is an X86 callee 392 or a Tapestry callee.) Caller 391 sets 393 the value of the XD 
register (R15 of Table 1) to a value that describes the layout in the Tapestry registers (R32-R47 

20 of Table 1) of its argument list. Then caller 391 issues a JALR instruction 394 to call to callee 
392. On arrival at the first instruction of callee 392, processor 100 recognizes a Tapestry-to-X86 
transition 395. Execution vectors (arrow ^1?)) to Tapestry-to-X86 exception handler (340 of Fig. 
3i). The four low-order bits XD<3:0> were set by instruction 393 to contain a basic 
classification of the XD descriptor, and execution is dispatched 341 according to those four bits, 

25 typically to code segment 343-345 or to segment 343, 346, 347. The dispatched-to code segment 
moves 347 the actual parameters from their Tapestry homes to their X86 homes, as directed by 
the remainder of the XD register. Handler 340 overwrites 345, 346 the two low-order bits of the 
return PC, LR<1 :0> with either "10" or "11" to indicate the location in which caller 391 expects 
the return result, as described in Table 3. Handler 340 retums (arrow (l6)) to the first instruction 

30 of X86 callee 392, which executes in the conventional manner. When callee 392 completes, an 
X86 RET instruction retums control to caller 391 (arrow ^^). The first instruction fetch from 
caller 391 will trigger a transition exception 396. The exception vectors (arrow ^18^) control to 
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X86-to-Tapestry handler 320. Based on the two low-order bits of LR, handler 320 reformats 
and/or repositions 330, 333, 334 the function return value. The handler completes 336, 338, and 
returns control (arrow (^) to the instruction in caller 391 following the original call 394. 

Referring again to Figs. 3a and 31, the complexity is confined to cases of cross-ISA calls. 
5 Complexity in handling cross-ISA calls is acceptable because transparent cross-ISA calling is not 
previously known in the art. In a case where caller, callee, and operating system all share a 
common ISA, no transition exceptions occur. For instance, when a Tapestry process 314 calls 
(arrow ^O)) the same Tapestry library routine 308, routine 308 enters through NATIVE entry 
point 318, or takes the Tapestry short path through GENERAL entry point 317. (Note that 

10 routine 308 will have to be separately mapped 397 into the address space of Tapestry process 
314 - recall that Tapestry process 314 is under the management of Tapestry OS 312, while the 
address space 380 of an X86 process is entirely managed by X86 operating system 306, entirely 
outside the ken of Tapestry operating system 312.) If the same external interrupt 388 occurs 
(arrow @)), the interrupt can be handled in Tapestry operating system 312 (outside the code of 

1 5 Fig. 3j), and control will directly resume (arrow ^2)) at the instruction following the interrupt, 
without tracing through the succession of handlers. When Tapestry library routine 308 
completes, control will return to the caller (arrow (23)) in the conventional manner. The only 
overhead is a single instruction 393, setting the value of XD in case the callee is in X86 code. 



20 H. Alternative embodiments 

In an alternative embodiment, a "restore target page" of memory is reserved in the 

operating system region of the X86 address space. In PFAT 172, ISA bit 180 for the restore 
target page is set to indicate that the instructions on the page are to be interpreted under the 
Tapestry instruction set. This restore target page is made nonpageable. At step 363 of Fig. 3j, 

25 the EIP value is replaced with an X86 address pointing into the restore target page, typically with 
byte offset bits of this replacement EIP storing the number of the save slot. In an alternative 
embodiment, the EIP is set to point to the restore target page, and the save slot number is stored 
in one of the X86 registers, for instance EAX. In either case, when X86 operating system 306 
resumes the thread, the first instruction fetch will trigger an X86-to-Tapestry transition 

30 exception, before the first actual instruction from the restore target page is actually executed, 

because the restore target page has the Tapestry ISA bit set in its PFAT and I-TLB entries. X86- 
to-Tapestry transition handler 320 begins by testing the address of the fetched instruction. An 
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address on the restore target page signals that there is extended context to restore. The save slot 
number is extracted from the instruction address (recall that the save slot number was coded into 
the EPC or EAX on exception entry, both of which will have been restored by X86 operating 
system 306 in the process of resuming the thread). The processor context is restored from the 
5 save slot, including the EPC.EIP value at which the thread was originally interrupted. In an 
alternative embodiment, only the extended context (not including the X86 context) is restored 
from the save slot, so that any aherations to the X86 context effected by Tapestry operating 
system 312 are left intact. X86-to-Tapestry transition handler 320 executes an RFE 338 to 
resume execution in the interrupted Tapestry code. 

10 Note that no instruction from the restore target page is actually executed; the address is 

simply a flag to X86-to-Tapestry transition handler 320. All that is required is that the address of 
the restore target page be representable in the X86 address space, so that the address can pass 
through X86 operating system 306 and its thread scheduler. In alternative embodiments, a fetch 
from the restore target page could raise another exception - an unaligned instruction fault, or an 

1 5 access protection fault. It is desirable, however, that the fault raised be one not defined in the 
X86 architecture, so that no user program can register a handler for the fault. 

In this alternative embodiment, the "01" case 370 of X86-to-Tapestry transition handler 
320 may also save the X86 thread's privilege mode, and reset the privilege level to user, even if 
the X86 caller was running in privilege ring zero. The privilege mode is changed to protect 

20 system integrity, to disallow a Tapestry Trojan horse from subverting X86 security checks. 

In an alternative embodiment, the correspondence between save slots and X86 threads is 
maintained by using thread-ID calls into X86 operating system 306. Each save slot 355 may be 
associated with a Windows thread number for the duration of that thread. A garbage collector 
may be used to recognize save slots that were filled a long time ago and are now apparently 

25 abandoned. The garbage collector reclaims save slots after a system-tunable time period, or on a 
least-recently-fiUed basis, on the assumption that the thread was terminated by X86 operating 
system 306. 

In another alternative embodiment, when Tapestry takes an exception while in X86 
converter mode, the extended context is snapshotted as well. If the operating system uses the 
30 X86 TSS (Task-State Segment) to implement muhi-tasking, then the PSW portion of the 

extended context (ISA 194, XP / calling convention 196, and semantic class 206, see section IV, 
infra) can be snapshotted into unused parts of the X86 TSS. Otherwise the amount of data 
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involved, five bits (ISA bit 194, XP / calling convention bit 196, and semantic context 206), is 
small enough that it can be squirreled away within the ten unused bits at the top of EFLAGS. In 
some embodiments, it may be possible to push the extended context as an additional word 
pushed onto the exception stack in X86 space. 
5 In another alternative embodiment, the extended context can be stored in memory in 

Tapestry space, where it is inaccessible to the X86. A hash table (or an equivalent associative 
software structure) links a particular X86 exception fi^ame to its associated snapshot of the 
extended Tapestry context, so that on exception exit or task rescheduling, when the processor 
reloads a particular X86 context into the EPC (error PC and program status word), in turn to be 
1 0 reloaded into the PSW by an RFE instruction (or when an X86 POPF instruction is emulated), 
the extended Tapestry context can be located and placed in the EPC as well. 

IV. An alternative method for managing transitions from one ISA to the other 

A. Indicating the calling convention (CC) for program text 

1 5 Sections IV.A and IV.B together describe an alternative mechanism used to determine the 

conventions under which data are passed to or from a subprogram, and thus the locations in 
which subprogram arguments or a function return value are stored before a control-transfer 
event, so that an exception handler can move the data to the locations expected by the code to be 
executed after the control-flow event. 

20 In the alternative Tapestry emulation of the X86 CISC architecture, any particular extent 

of native code observes one of two different calling conventions (see section IILB, supra): one 
RISC register-based calling convention for calls from native Tapestry code to native Tapestry 
code, and another quasi-Cl^C memory-based convention that parallels the emulated CISC 
calling convention, for use when it is believed likely that the call will most frequently cross from 

25 one ISA to the other. The features described in sections IV.A and IV.B provide sufficient 
information about the machine context so that a transition from one ISA to the other can be 
seamlessly effected. 

Referring again to Fig. 3a, programs coded in the native Tapestry instruction set, when 
calling a subprogram, may use either a register-based RISC calling convention, or a memory- 
30 based calling convention that parallels the X86 convention. In X86 converter mode, all 

subprogram calls use the memory-stack-based calling convention. In either mode, control may 
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be transferred by an internal jump in which the data passes from source to destination simply by 
its location in certain memory or register locations. 

Program text regions 176 are aimotated with a bit 200 that indicates the calling 
convention used by the code in the region. When execution flows from a source observing one 

5 calling convention to a destination observing another, the difference in calling convention bits 
200 will trigger a transition exception. The transition exception handler copies the subprogram 
arguments from the well-known location established by the source convention to the well-known 
location expected by the destination. This allows caller and callee subprograms to be compiled 
with no reliance on the calling convention used by the other, and allows for more seamless 

10 system operation in an environment of binaries and libraries of inhomogeneous ISA. 

Referring to Figs. Id and 2a, calling convention bit 200 is stored in PFAT entries 174 
and I-TLB 116 in a manner analogous to ISA bit 180, 182 with a record of the calling convention 
of the previous instruction available in PSW 190 calling convention bit 196, as discussed in 
section II, supra; the alternative embodiments discussed there are equally applicable here. 

15 (Because the calling convention property 200 is only meaningful for pages of Tapestry code, and 
the XP write-protect property 184, 186 (discussed in section I.F, supra) is only used for pages of 
X86 code, the two properties for a given page can encoded in a single physical bit, overlaying 
the XP write-protect bits 184, 186 - this single bit has different meanings depending on the 
PSW.ISAbit 194.) 

20 Referring to Figs, 2b and 2c, when execution crosses (column 204) from a region of one 

calling convention 200 to a region of another calling convention 200, the machine takes an 
exception. Based on the direction of the transition (Tapestry-to-X86 or X86-to-Tapestry) and a 
classification (as shown in Table 4 and discussed in IV.B, infra) of the instruction that provoked 
the transition, the exception is vectored to an exception handler that corresponds to the direction 

25 and classification. The eight calling convention transition exception vectors are shown in the 
eight rows 242-256 of Fig. 2c. (The eight exception vectors for calling convention transitions 
are distinct from the two exception vectors for ISA transitions discussed in section II, supra.) 
The exception vectoring is specific enough that arrival at a specific handler largely determines a 
mapping from the old machine context to a machine context that will satisfy the preconditions 

30 for execution in the new environment. The exception handler implements this mapping by 

copying data from one location to another. The exception handler operates during an exception 
interposed between the source instruction and the destination instruction, transforming the 
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machine context from that produced by the last instruction of the source (for instance, the 
argument passing area estabUshed before a CALL) to the context expected by the first instruction 
of the destination (the expectations of the code that will begin to use the arguments). 

Further information used to process the transition exception, and the handling of 
5 particular exception cases, is described in section IV.B, infra, 

B. Recording Transfer of Control Semantics and Reconciling Calling 
Conventions 

Merely knowing the direction of a transition (from X86 calling convention to Tapestry 
10 convention or vice versa) is insufficient to determine the actions that must be taken on a 

transition exception when the data storage conventions disagree. This section describes a further 
technique used to interpret the machine context, so that the appropriate action can be taken on a 
transition exception. In overview, as each control-transfer instruction is executed, the intent or 
semantic class of the instruction is recorded in the SC (semantic class) field 206 (PSW.SC) of 
15 PSW (the Program Status Word) 190. On a transition exception, this information is used to 

vector to an exception handler programmed to copy data from one location to another in order to 
effect the transition from the old state to the new precondition. 

Table 4 



ISA of 
source 


semantic 

class 

value 


Meaning 


representative instructions 


Tap 


00 


Call 


JAL, JALR 


Tap 


01 


Jump 


conditional jump, J, JALR 


Tap 


10 


Return with no FP result 


JALR 


Tap 


11 


Return with FP result 


JALR 


X86 


00 


Call 


CALL 


X86 


01 


Jump 


JMP, Jcc 


X86 


10 


Return with no FP result 


RET 


X86 


11 


Return with (possible) FP 
result 


RET 



20 Referring to Figs, le and 2c and to Table 4, the control-flow instructions of both the 

Tapestry ISA and the X86 ISA are classified into five semantic classes: JUMP, CALL, 
RETURN-NO-FP (retum from a subprogram that does not return a double-precision floating- 
point result), RETURN-FP (retum from a subprogram that definitely returns a double-precision 
floating-point result, used only in the context of retuming from a Tapestry native callee), and 



Atty. Docket No. 30585/28 

NYDOCS04/ 285781 



78 



Express Mail Label EI465234796US 



RETURN-MA YBE-FP (return from a subprogram that may return or definitely returns either a 
64-bit double-precision or 80-bit extended precision floating-point result, used only in the 
context of returning from an X86 callee). Because there are four possible transfers for each ISA 
mode, two bits 206 (combined with PSW.ISA bit 194) are sufficient to identify the five states 
5 enumerated. 

Most of this semantic classification is static, by instruction opcode. Some instructions, 
e.g., the X86 Jump and CALL instructions, are semantically unambiguous. For instance, an X86 
RET cannot be mistaken for a CALL or an internal control flow JUMP. Thus, even though the 
Tapestry system never examines the source code for the X86 binary, the X86 instruction contains 

10 sufficient information in its opcode to determine the semantic class of the instruction. 

Referring to Table 4, some of the semantic classification is encoded into instructions by 
the compiler. For instance, the Tapestry JALR instruction indirect to the location 
specified by the instruction's source register, and store the link IP (instruction pointer) in the 
destination register), may serve any of several roles, for instance as a return from subprogram 

15 (the link IP is stored into the read-zero register), a FORTRAN assigned go-to within a single 
routine, or a subprogram call. To resolve the ambiguity of a JALR instruction, bits that are 
unused in the execution of the instruction are filled in by the compiler with one of the semantic 
class codes, and that code is copied as an immediate from the instruction to PSW.SC 206 when 
the instruction is executed. In the case of Tapestry native binaries compiled from source code, 

20 this immediate field of the JALR instruction is filled in with the aid of semantic information 
gleaned either from the source code of the program being compiled. In the case of a binary 
translated from X86 to Tapestry, the semantic class of the X86 instruction is used to determine 
the semantic class of the corresponding Tapestry instruction. Thus, the Tapestry compiler 
analyzes the program to distinguish a JALR for a branch to a varying address (for instance a 

25 FORTRAN assigned or computed go-to, or a CASE branch through a jump table) from a JALR 
for a function return (fiirther distinguishing the floating-point from no-floating-point case) from a 
JALR for a subprogram call, and explicitly fills in the two-bit semantic class code in the JALR 
instruction. 

Some of the semantic classification is performed by execution time analysis of the 
30 machine context. X86 RET (return from subprogram) instructions are classified into two 

semantic context classes, RETURN-NO-FP (return from subprogram, definitely not returning a 
floating-point function result) and RETURN-MA YBE-FP (return, possibly or definitely 
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returning a floating-point function result). The X86 calling convention specifies that a floating- 
point function result is returned at the top of the floating-point stack, and integer function results 
are returned in register EAX. The instruction opcode is the same in either case; converter 136 
classifies RET instructions on-the-fly based on the X86 floating-point top-of-stack. If the top-of- 
5 stack points to a floating-point register marked empty, then the X86 calling convention 

unambiguously assures that the RET cannot be returning a floating-point value, and the semantic 
class is set to RETURN-NO-FP. If the top-of-stack register points to a full location, there may 
nonetheless be an integer return value; the semantic context is set to RETURN-MA YBE-FP to 
indicate this ambiguity. 

10 On an exception, PSW 190 (including ISA bit 194, calling convention bit 196, and SC 

field 206) is snapshotted into the exception PSW, a control register of the machine. The PSW 
bits in the exception PSW are available for examination and modification by the exception 
handler. When the exception handler completes, the RFE (return from exception) instruction 
restores the snapshotted exception PSW into the machine PSW 190, and machine execution 

15 resumes. Thus, PSW.SC 206 is preserved across exceptions, even though it is updated during 
execution of the exception handler (unless the exception handler deliberately modifies it by 
modifying the exception PSW). 

Figs. 2b and 2c show how calling convention transitions are vectored to the exception 
handlers. On a calling convention transition exception, five data are used to vector to the 

20 appropriate handler and determine the action to be taken by the handler: the old ISA 180, 182, 
the mw ISA 180, 182, the old calling convention 196, the new calling convention 196, and 
PSW.SC 206. In Fig. 2b, the first column 204 shows the nature of the transition based on the 
first four, the transition of the ISA and CC bits. For instance, the third line 216 discusses a 
transition from native Tapestry ISA using native Tapestry register-based calling conventions 

25 (represented as the value "GO" of the ISA and CC bits) to X86 code, which necessarily uses the 
X86 calling convenfion (represented as the value "Ix," "1" for the X86 ISA, and "x" for "don't 
care" value of the CC bit). Table 4 shows that several different situations may vector to the same 
exception handler. Note, for instance, that lines 214 and 216 vector to the same group of four 
handlers, and lines 218 and 224 vector to the same group of handlers. These correspondences 

30 arise because the memory manipulation required to convert from native Tapestry calling 
convention to X86 calling convention, or vice versa, is largely the same, whether the X86 
convention is observed by native Tapestry instructions or X86 instructions. 
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Fig. 2c shows how the machine vectors to the proper exception handler based on 
semantic class. For instance, lines 242, 244, 246, and 248 break out the four possible handlers 
for the 00=>01 and 00^>lx (native Tapestry code using native calUng conventions, to X86 code 
using X86 conventions) ISA and CC transitions, based on the four possible semantic classes of 
5 control-flow instruction. Lines 250, 252, 254, and 256 break out the four possible handlers for 
the 01=>00 and lx=>00 transitions, based on the four semantic classes of instruction that can 
cause this transition. 

Referring to Fig. 2b, when crossing from one subprogram to another, if the source and 
destination agree on the convention used for passing arguments, either because they agree on 

10 ISA and caUing convention (rows 212, 220, 228, 230), or agree on calling convention even 
though disagreeing on ISA (rows 222, 226), or because the data pass simply by virtue of being 
stored in the same storage location in the source and destination execution environments (rows 
244, 252), then no intervention is required. For instance, when crossing from the X86 ISA using 
the X86 calling convention to the Tapestry native ISA using the X86 convention, or vice-versa, 

1 5 data passes from one environment to the other, without actually moving from one hardware 
element to another, using the fixed mapping between X86 virtual resources and Tapestry 
physical resources using the fixed mapping shown in Table 1 and discussed in section LB, supra. 

For instance, as shown in row 222, if a caller in Tapestry native code, using the memory 
based quasi-XSG calling convention, calls a routine in X86 code (or vice-versa, row 226), no 

20 arguments need be moved; only the instruction decode mode need be changed. 

On the other hand, if the calling conventions 200 disagree, and the arguments are being 
passed under one calling convention and received under another, the calling convention 
exception handler intervenes to move the argument data from the well-known locations used by 
the source convention to the well-known locations expected by the destination convention. For 

25 instance, a subprogram CALL from an X86 caller to a callee in native Tapestry code that uses 
the native Tapestry calling convention (rows 224, 250), or equivalently, from Tapestry code 
using X86 conventions to native Tapestry using the native convention (rows 218, 250), must 
have its arguments moved from the locations specified by the memory stack-based caller 
convention to the locations specified by the register-based callee convention. 

30 Rows 214, 242 of Figs, 2b and 2c show the case of a subprogram call where the caller is 

in Tapestry native code using the register-based native calling convention, and the callee is in 
Tapestry native code but uses the quasi-XS6 calling convention. (Similarly, as shown in rows 
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216, if the caller is in Tapestry native code using the register-based native calling convention, 
and the callee is coded in the X86 ISA, then the same exception handler 242 is invoked, and it 
does the same v^ork.) The exception handler will push the subprogram arguments from their 
register positions in which arguments are passed under the native convention, into their memory 

5 stack positions as expected under the X86 calling convention. If the arguments are of varying 
size, the X86 stack layout of the argument buffer may be rather complex, and the mapping from 
the arguments in Tapestry registers to that argument buffer will be correspondingly complex. 
The argument copying is specified by a descriptor, an argument generated by the compiler for 
annotation of the caller site. This is particularly important for "varargs" routines. Because the 

10 native caller was generated by the Tapestry compiler, the compiler is able to produce a descriptor 
that fully describes the data copying to be performed by the transition exception. The descriptor 
is analogous to the argument descriptors generated by compilers for use by debuggers. The data 
will then be in the locations expected by the callee, and execution can resume in the destination 
ISA mode. 

1 5 When an X86 caller (or a Tapestry caller using the quasi-XS6 calling convention), the 

data of the argument block established by the caller are copied into the locations expected by the 
Tapestry callee. For instance, the linkage return address is copied from the top of stack to r6 (the 
Tapestry linkage register, given the alias name of LR for this purpose). The next few bytes of 
the stack are copied into Tapestry registers, for quick access. A call descriptor (a datum that 

20 describes the format of the call arguments) is manufactured in register r5 1 (alias CD), set to 

indicate that the arguments are passed under the X86 convention. A null return value descriptor 
is manufactured on the stack; the return descriptor will be modified to specify the format of the 
return value, once that information is known. 

When returning from a callee function, the calling convention 200 of the caller and callee 

25 and the semantic class 206 of the retum instruction determine the actions needed to put the 
function retum value in the correct location expected by the callee. As shown in Table 1 , the 
X86 calling convention returns double-precision floating-point function retum values in the 
floating-point register indicated by the top-of-floating-point-stack. The X86 calling convention 
returns other scalars of 32 bits or less in register EAX, results of 33 to 64 bits in the EAX:EDX 

30 register pair, and function retum values of 65 bits or greater are retumed in a memory location 
pointed to by an argument prepended to the caller's argument list. The native Tapestry calling 
convention returns double-precision floating-point values in r31 (for this purpose, given the alias 
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name of RVDP), other return values of 256 bits or less in registers r48, r49, r50, and r51 (given 
the alias names of RVO, RVl, RV2, and RV3), and larger return values in a memory location 
pointed to by r3 1 (for this purpose, given the alias name of RVA). 

The Tapestry calling convention, and the mapping between Tapestry and X86 resources, 

5 are co-designed, at least in part, to maximize common uses, thereby to reduce the amount of data 
copying required on a calling convention transition. Thus, the two registers used to return scalar 
function return values - r48 (RVO) in Tapestry, EAX in X86 - are mapped to each other. 

When returning from a native-convention callee to an X86 or a Tapestry-using-X86- 
convention caller, the semantic class of the retum is unambiguously known (because whether the 

10 function retums a floating-point value or not was encoded in the semantic class bits of the JALR 
instruction by the compiler), and the semantic class distinguishes the two actions to take in the 
two cases that may arise, as discussed in the next two paragraphs. 

When a native-convention function retums a double-precision (64-bit) floating-point 
value to an X86-convention caller (the RETURN-FP case of row 248), the function retum value 

1 5 is inflated from an IEEE-754 64-bit representation in r3 1 (RVDP, the register in which Tapestry 
retums double-precision ftinction results) to an 80-bit extended precision representation in the 
register pair to which the X86 FP top-of-stack currently points (usually r32-r33, the Tapestry 
register pair mapped to FO of the X86). The top-of-floating-point stack register is marked full, 
and all other floating-point registers are marked empty. (Tapestry has a floating-point status 

20 register that subsumes the function of the X86 FPCW (floating-point control word), FPSW 

(floating-point status word), and FPTW (floating-point tag word), and the registers are marked 
full or empty in the tag bits of this status register.) 

On a retum from a non-floating-point Tapestry native callee function to an X86- 
convention caller (the RETURN-NO-FP case of row 248) to an X86-convention caller, the 

25 function retum value is left alone in r48, because this single register is both the register in which 
the Tapestry function computed its result, and the register to which the X86 register EAX (the 
function-result retum register) is mapped. The entire floating-point stack is marked empty. 

If the native callee is returning a value larger than 64 bits to an X86-convention caller, a 
retum descriptor stored on the stack indicates where the retum value is stored (typically in 

30 registers r48 (RVO), r49 (RVl), r50 (RV2), and r5 1 (RV3), or in a memory location pointed to 
by r31 (RVA)); the return value is copied to the location specified under the X86 convention 
(typically a memory location whose address is stored in the argument block on the stack). 
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When returning from an X86 callee to a Tapestry-using-X86-convention caller, no action 
is required, because the register mapping of Table 1 implements the convention transformation. 

When returning from an X86 callee to a native Tapestry caller, two cases are 
distinguished by the two semantic classes RETURN-MAYBE-FP and RETURN-NO-FP. For 

5 the RETURN-NO-FP case of rows 224 and 254, no action is required, because the return value 
was computed into X86 register EAX, which is mapped to r48, the Tapestry scalar return value 
register. For the RETURN-MAYBE-FP case, the exception handler conservatively ensures that 
any scalar resuU is left in r48, and also ensures that the value from the top of the floating-point 
stack is deflated from an 80-bit extended-precision representation to a 64-bit double-precision 

10 representation in r3 1 (RVDP). 

When executing translated native code, Tapestry will not execute a JALR subprogram 
retum unless the destination is also in native code. Because the semantic class codes on the 
present implementation only ambiguously resolve whether an X86 instruction does or does not 
retum a floating-point result (RETURN-FP vs. RETURN-MAYBE-FP), and the native semantic 

1 5 class codes are unambiguous (RETURN-FP vs. RETURN-NO-FP), binary translator 124 does 
not translate a final X86 RET unless its destination is also translated. 

An alternative embodiment may provide a third calling convention value, a "transition" 
value. The machine will not take an exception when crossing to or from a transition page - the 
transition calling convention "matches" both the X86 calling convention and the Tapestry calling 

20 convention. Typically, pages of transition calling convention will have a Tapestry ISA value. 
These transition pages hold "glue" code that explicitly performs the transition work. For 
instance, an X86 caller that wants to call a Tapestry callee might first call a glue routine on a 
transition calling convention page. The glue routine copies arguments from their X86 calling 
convention homes to their Tapestry homes, and may perform other housekeeping. The glue 

25 routine then calls the Tapestry callee. The Tapestry callee retums to the glue routine, where the 
glue routine performs the retum value copying and performs other housekeeping, and retums to 
its caller, the X86 caller. 

One of ordinary skill will understand the argument copying that implements each of the 
cases of transition exception shown in Figs. 2b and 2c. One embodiment is shown in frill detail 

30 in the microfiche appendices of U.S. applications serial no. 09/385,394, 09/322,443, and 
09/239,194, which applications are incorporated herein by reference. 
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In an embodiment alternative to any of the broad designs laid out in sections II, III, or IV, 
the computer may provide three or more instruction set architectures, and/or three or more 
calling conventions. Each architecture or convention is assigned a code number, represented in 
two or more bits. Whenever the architecture crosses from a region or page with one code to a 
5 region or page with another, an appropriate adjustment is made to the hardware control, or an 
appropriate exception handler is invoked, to adjust the data content of the computer, and/or to 
explicitly control the hardware execution mode. 

V. Profiling to determine hot spots for translation 

10 A. Overview of profiling 

Referring to Figs, la, lb and 4a, profiler 400 monitors the execution of programs 

executing in X86 mode, and stores a stream of data representing the profile of the execution. 
Because the X86 instruction text is typically an off-the-shelf commercial binary, profiler 400 
operates without modifying the X86 binary, or recompiling source code into special-purpose 

1 5 profileable X86 instruction text. The execution rules for profiler 400 are tailored so that the right 
information will be captured at the right time. Hot spot detector 122 identifies hot spots in the 
programs based on the profile data. The data collected by profiler 400 are sufficiently 
descriptive to allow the application of effective heuristics to determine the hot spots from the 
profile data alone, without fiarther reference to the instruction text. In particular, the profile 

20 information indicates every byte of X86 object code that was fetched and executed, without 
leaving any non-sequential flow to inference. Further, the profile data are detailed enough, in 
combination with the X86 instruction text, to enable binary translation of any profiled range of 
X86 instruction text. The profile information annotates the X86 instruction text sufficientiy well 
to resolve all ambiguity in the X86 object text, including ambiguity induced by data- or machine- 

25 context dependencies of the X86 instructions. Profiler 400 operates without modifying the X86 
binary, or recompiling source code into a special-purpose profileable X86 binary. 

In its most-common mode of operation, profiler 400 awaits a two-part trigger signal (516, 
522 of Fig, 5a) to start sampling events, and then records every profileable event 416 in a dense 
sequence, including every profileable event that occurs, until it stops (for instance, on exhaustion 

30 of the buffer into which profile information is being collected), as opposed to a conventional 

profiler that records every event, or records a single event every n microseconds. The profile 
information records both the source and destination addresses of most control flow transfers. 

Atty. Docket No. 30585/28 85 Express Mail Label EI465234796US 

NYDOCS04/ 285781 



Entries describing individual events are collected into the machine's general register file, and 
then stored in a block as a profile packet. This blocking of events reduces memory access traffic 
and exception overhead. 

Referring again to Figs, la and lb, profiler 400 tracks events by physical address, rather 

5 than by virtual address. Thus, a profitable event 416 may be induced by "straight line" flow in 
virtual address space, when two successive instructions are separated by a physical page 
boundary, or when a single instruction straddles a virtual page boundary. (As is known in the 
art, two pages that are sequential in a virtual address space may be stored far from each other in 
physical memory.) By managing the X86 pages in the physical address space. Tapestry operates 

10 at the level of the X86 hardware being emulated. Thus, the interfaces between Tapestry and X86 
operating system 306 may be as well-defined and stable as the X86 architecture itself This 
obviates any need to emulate or accovmt for any policies or features managed by the operating 
system 306. For instance, Tapestry can run any X86 operating system (any version of Microsoft 
Windows, Microsoft NT, or IBM OS/2, or any other operating system) without the need to 

1 5 account for different virtual memory policies, process or thread management, or mappings 

between logical and physical resources, and without any need to modify operating system 306. 
Second, if X86 operating system 306 shares the same physical page among multiple X86 
processes, even if at different virtual pages, the page will be automatically shared. There will be 
a single page. Third, this has the advantage that pages freed deleted from an address space, and 

20 then remapped before being reclaimed and allocated to another use. 

Referring to Fig. 4b, events are classified into a fairly fine taxonomy of about thirty 
classes. Events that may be recorded include jumps, subprogram CALL'S and returns, interrupts, 
exceptions, traps into the kernel, changes to processor state that alters instruction interpretation, 
and sequential flow that crosses a page boundary. Forward and backward jumps, conditional and 

25 unconditional jumps, and near and far jumps are distinguished. 

Referring to Figs. 4g and 4h, profiler 400 has a number of features that allow profiling to 
be precisely controlled, so that the overhead of profiling can be limited to only those execution 
modes for which profile analysis is desired. 

Referring to Figs. 5a and 5b, as each X86 instruction is decoded by the converter (136 of 

30 Fig. Ic), a profile entry is built up in a 64-bit processor register 594. During execution of the 
instruction, register 594 may be modified and overwritten, particularly if the instruction traps 
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into Tapestry operating system 312. At the completion of the instruction, profiler 400 may 
choose to captxire the contents of the profile entry processor register into a general register. 

Hot spot detector 122 recognizes addresses that frequently recur in a set of profile 
packets. Once a hot spot is recognized, the surrounding entries in the profile may indicate (by 
5 physical address) a region of code that is frequently executed in correlation with the recurring 
address, and the path through the physical pages. Hot spot detector 122 conveys this information 
to TAXi translator 124, which in turn translates the binary. 

B. Profileable events and event codes 

10 Referring to Fig. 4b, profiler 400 recognizes and records about thirty classes of events, 

listed in the table. Each class of event has a code 402, which is a number between 0 and 31, 
represented as a five-bit number. The class of events is chosen to provide both the minimum 
information required to support the design, and additional information that is not strictly 
necessary but may provide additional hints that allow hot spot detector 122 to achieve better 
15 results. 

The upper half 410 of the table lists events that are (in one embodiment) raised by 
software, and lower half 404 contains events raised by hardware. The lower half will be 
discussed first. 

The lower half 404 of the table, the sixteen entries whose high-order bit is One, are 
20 events induced by converter 136. As each X86 instruction is decoded and executed, the events 
enumerated in lower half 404 are recognized. If profiler 400 is active when one of these events 
404 occurs, a profile entry is recorded in a general register. The events in the lower half of the 
table fall into two classes: near transfers of control that are executed in converter 136, and 
sequential flows of execution across a physical page frame boundary. 
25 Profiler 400 captures transfers of control, including IP-relative transfers, subroutine calls 

and returns, jumps through pointers, and many interrupt-induced transfers. Even though profiler 
400 views the machine in its physical address space, the distinction between forward and 
backwards jumps can be determined for PC-relative jumps by looking at the sign bit of the PC- 
relative displacement in the X86 instruction. Once the branch is classified, the classification is 
30 encoded in event code 402 stored in the profile entry for the branch. There are event codes 402 
to separately classify forward conditional branches, backward conditional branches, three 
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separate classes of conditional jump predicates, etc., as shown by event codes 1.0000, 1.0001, 
1.0010, 1.0011, 1.0100, 1.0101, and 1.0111. 

Event code 1.1 100 is discussed in section VIII.B. 

Event code 1.1110 406 indicates a simple sequential instruction with nothing of note. 

5 Event code 1.1111 408 denotes an instruction that either ends in the very last byte of a physical 
page or straddles a page boundary in virtual address space (and is likely separated into two 
distant portions in the physical address space). 

The upper half 410 of the table, the top sixteen entries whose high-order bit is Zero, are 
events that are handled in software emulator 316, and recorded during execution of a Tapestry 

10 RFE (return from exception) instruction at the completion of the emulation handler. RFE is the 
Tapestry instruction that returns from Tapestry operating system 312 to a user program after a 
synchronous exception,(for instance a page fault or NaN-producing floating-point exception), an 
asynchronous external interrupt, or a trap into emulator 316 for simulation of a particularly 
complex X86 instruction that is not implemented m the hardware converter 136. Generally, the 

1 5 events in the upper half of the table fall into four classes: (1) far control transfer instructions 
executed in emulator 316, (2) instructions that update the X86 execution context {e.g. FRSTOR) 
executed in emulator 316, (3) delivery of X86 internal, synchronous interrupts, and (4) delivery 
of X86 extemal, asynchronous interrupts. In general the upper-half event codes are known only 
to software. 

20 Each RFE instruction includes a 4-bit immediate field (588 of Fig. 5b) in which is stored 

the low-order four bits of the event code 402 associated with the event that invokes the retumed- 
from handler. The fifth bit in an RFE event class is reconstructed (see section V.G, infra) as a 
Zero, even though the Zero is not explicitly stored. When the RFE is executed, the event code 
from the RFE is copied into TAXi_State.Event_Code_Latch (486, 487 of Figs. 4h and 5b) and 

25 the temporary processor register (594 of Fig. 5b) that collects profile information (see section 
V.F, infra), overwriting the event code supplied by converter 136. From register 594, the event 
code will be copied into a general register if a profile entry is to be collected. This mechanism 
allows software to signal profiler 400 hardware 510 that a profitable instruction has been 
executed in emulator 316, or that an otherwise non-profileable instruction executed in emulator 

30 316 caused a page crossing and should be profiled for that reason. (RFE's without X86 

significance will set this field to zero, which will prevent the hardware from storing a profile 
entry - see the discussion of code 0.0000, infra) 
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The "profileable event" column (416 of Fig, 4b) specifies whether an the event code is to 
be included in a profile packet. Events that are not profileable simply occur v^th no action being 
taken by profiler 400. The "initiate packet" column 418 specifies whether an event of this event 
code (402 of Fig. 4b) is allowed to initiate collection of a new profile packet, or whether this 

5 event class may only be recorded in entries after the first. "Initiate packet" 418 is discussed at 
length in sections V.F and V.G, infra, in connection with Context At Point profile entries. Fig. 
4c, and the profiler state machine 510, Fig. 5a. The "probeable event" column 610 and "probe 
event bit" column 612 will be discussed in cormection with Probing, section VI, infra. The 
"initiate packet" 418, "profileable event" 416, and "probeable event" 610 properties are 

10 computed by FLA (programmable logic array) 650, which is discussed in sections VLC and 
VI.D, infra. 

Discussion of event codes 0.0000, 0.0001, 0.0010 and 0.001 1 is deferred for a few 
paragraphs. 

An event code of 0.0100 is simply stored over the current value of 

1 5 TAXi_State.Event_Code_Latch (486, 487 of Fig. 4h and 5b), without fiirther effect of the 

current state of the machine. The effect of this overwrite is to clear the previously-stored event 
code, ensuring that converter 136 can restart without any effects that might be triggered by the 
current content of TAXi_State.Event_Code_Latch 486, 487. For instance, if converter 136 takes 
a probe exception (see section VI, infra), and the first instruction of the translated TAXi code 

20 generates an exception (e.g., a floating-point overflow) that should be handled by retuming 

control to converter 136 (rather than allowing execution to resume in the translated TAXi code), 
the exception handler will return with an RFE whose event code immediate field is 0.0100. This 
ensures that converter 136 will not restart with the event code pending in 
TAXi_State.Event_Code_Latch 486, 487 that triggered the probe exception in the first place. 

25 Event code 0.0101 indicates an emulator completion of an instruction that changes the 

execution context, for instance, the fiiU/empty state of the floating-point registers or floating- 
point top-of-stack. This will force the recording of Context At Point profile entry (see 430 of 
Fig. 4c and section V.C, infra) to capture the state change. 

Events of event code 0.01 10, 0.01 11, 0.1000, 0.1001 are control-transfer instructions that 

30 are conveniently implemented in emulation software instead of hardware converter 134, 136 
such as far CALL, far jump, far return, and X86 interrupt return. The event code taxonomy for 
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these far transfers does not differentiate forward and backward jumps, in contrast to the 
taxonomy of IP-relative near jumps (event codes 1.0000-1.0101). 

An RFE with an event code of 0.1010 causes TAXi_Control.special_opcode 474 (bits 
<50:44>) to be captured in the special_opcode 434 field (bits <50:43> of Fig. 4c) of a 
5 Context_At_Point profile entry (430 of Fig. 4c). This opens up a new seven-bit space of event 
codes that can be managed completely by software. 

Event code 0.101 1 is used to RFE from an exception handler, to force the current profile 
packet to be aborted. The Tapestry hardware recognizes the event code in the RFE immediate 
field and aborts the profile packet by clearing TAXi_State.Profile_^Active (482 of Figs. 4h and 

10 5a). For instance, this event code might be used after a successfiil probe RFE's to TAXi code 
and aborts any packet in progress. This is because the TAXi code represent a break in the 
sequential interval of a profile packet, and an attempt to continue the packet would render it ill- 
formed. Similarly, when X86 single-step mode is enabled, the RFE from emulator 316 uses 
event code 0.101 1 to abort a packet in progress. Profiling will resume at the next profile timer 

15 expiry. 

Event codes 0.1 100, 0.1 101, 0.1 1 10, and 0.1 1 1 1 provide two pairs of RFE event codes 
associated with delivery of X86 exceptions from X86 emulator 316. This allows software to 
group exceptions into different categories for TAXi usage. By classifying interrupts into two 
groups, and further into probeable and non-probeable events (see section VI, infra), these four 

20 event codes provide a control framework for software to build upon. This classification exploits 
the fact that the X86 funnels all exceptions, external interrupts, and traps through a single unified 
"interrupt" mechanism. 

Event codes 0.0000, 0.0001, 0.0010, and 0.0011 412 operate somewhat differently from 
the other events in upper half 410, as shown by the "reuse event code" colunm 414. Events of 

25 these classes (that is, RFE instructions with these four-bit codes in their event code immediate 
field) do not update TAXi_State.Event_Code_Latch (486, 487 of Fig. 4h) and related signals; 
the previously-latched event code is simply allowed to persist for the next X86 instruction. For 
example, event code 0.0000 is for "transparent" exceptions, exceptions that do not get recorded 
in the profile. As a specific example, the RFE's at the end of the handlers for TLB miss 

30 exceptions, interrupt service routines for purely-Tapestry interrupts, and other exceptions 

unrelated to the progress of an X86 program have event code 0.0000 (four explicit Zeros in the 
immediate field, and an assumed high-order Zero), which causes the hardware to resume 
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execution at the interrupted location without storing a profile entry. These events are kept 
architecturally invisible to the currently-executing process and are not correlated to any hot spot 
in that process, and thus recording an event would be specious. 

Event code 0.0001 is used in the software X86 emulator 316. Very complex X86 CISC 
5 instructions that are not implemented in hardware converter 136 are instead implemented as a 
trap into software, where the instruction is emulated. When X86 emulator 316 completes the 
instruction, it returns using an RFE with an event code of 0.0001 to indicate that "nothing special 
happened here," and so no profile entry is collected (unless the emulated instruction straddled a 
page). 

10 Another use of the "reuse event code" feature of column 414 is illustrated by considering 

the case of a complex instruction, an instruction that is emulated in software, that does not affect 
any control flow, for instance a compare string instruction. When such a complex instruction is 
encountered, converter 136, non-event circuit 578, and MUX 580 of Fig. 5b in section V.F, 
infra, will have made a preliminary decode of the instruction, and supplied a preliminary event 

1 5 code (582, 592 of Fig. 5b): either the defauft event code 1.1110 406 or a new page event code 
1.1111 408, depending on whether the instruction straddles a page break. (In some 
embodiments, converter 136 may in addition supply the event codes for far control transfers, far 
CALL, code 0.1000; far JMP, code 0.1001; far RET, code 0.0110; IRET, code 0.0111). This 
preliminary event code 582, 592 is latched into TAXi_State.Event_Code_Latch 486, 487 as part 

20 of trapping into X86 emulator 316. When X86 emulator 316 completes the complex instruction 
and RFE's back to converter 136, the RFE will have as its event code immediate field (588 of 
Fig. 5b) the simple X86 instruction-complete event code 0.0001. Because event code 0.0001 has 
"reuse event code" property 414, the event code from the RFE immediate field will simply be 
discarded, leaving intact the preliminary event code 582, 592 in TAXi_State.Event_Code_Latch 

25 486, 487. On return from the exception, an event with the preliminary event code is then added 
to the profile packet. 

Event codes 0.0010 and 0.001 1 are used in the RFE from the probe exception handler 
(see section VI, infra). If a probe fails, that class of probe is disabled. Because probing and 
profiling are mutually exclusive (see section VI.G, infra), when there is a probe exception, 
30 profiling is not active. Thus, these event codes are never stored in a profile packet, but exist to 
control prober 600, as described in section VLD, infra, 
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C. Storage form for profiled events 

Referring to Figs. 4a, 4c, and 4d, profile events are collected and stored in groups called 
packets 420. Each profile packet 420 holds a programmable number of entries, initially collected 
into registers R16-R3 1, and then stored to memory. In a typical use, there will be sixteen entries 

5 per packet, beginning with a 64-bit time stamp, then fourteen event entries 430, 440, and an 
ending time stamp. Each event is described as a 64-bit entry, of one of two forms: a 
Context_At_Point entry 430, or a Near Edge entry 440. The first entry in the packet is always a 
Context_At_Point entry 430, which gives a relatively complete snapshot of the processor context 
at the point that profiling begins, a point conceptually between two X86 instructions. 

10 Subsequent entries may be of either Context_At_Point or Near^Edge form. A Near_Edge entry 
440 describes an intra-segment (i.e., "near") control transfer, giving the source and destination of 
the transfer. At a Near^Edge entry 440, the remainder of the X86 processor context can be 
determined by starting at the most-recent Context_At_Point entry 430 and inferring the processor 
context by interpreting the instructions that intervened between that Context_At_Point and the 

1 5 Near Edge transfer. Sufficient information is present in the profile so that the context can be 
inferred by binary translator 124 by reference only to the opcodes of those intervening 
instructions, without requiring any knowledge of the actual data consumed or manipulated by 
those instructions. The rules for emitting a Context_At_Point entry 430 preserve this invariant: 
processor context is inferable from the combination of the profile and the opcodes of the 

20 intervening instructions, without reference to any data consumed or manipulated by the 
instructions. If execution of an X86 instruction depends on memory data or the processor 
context bits in a manner not representable in a Near_Edge entry 440, then profiler 400 emits a 
Context_At_Point entry 430. Thus, Context_At_Point entries ensure that the TAXi binary 
translator 124 has sufficient information to resolve ambiguity in the X86 instruction stream, in 

25 order to generate native Tapestry code. 

Referring to Fig. 4c, a Context_At_Point entry 430 describes an X86 instruction 
boundary context snapshot, a context in effect as execution of an X86 instruction is about to 
begin. 

Bits <63:60> 431 of a Context_At_Point entry 430 are all Zero, to distinguish a 
30 Context_At_Point entry 430 from a Near_Edge entry 440. (As noted in the discussion of 

done_length 441, bits <63:60> of Fig. 4d, infra, in a Near_Edge 440 the first four bits record the 
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length of an instruction, and there are no zero-length instructions. Thus, a zero value in field 431 
unambiguously indicates a Context_At_Point 430.) 

Bits <59:51> 432, 433 and <42:32> 435 capture the processor mode context of the X86 
at the instruction boundary (before the start of the instruction described in next_frame 438 and 
5 next_byte 439, bits <27:00>). The bits of an X86 instruction do not completely specify the 
action of the instruction; the X86 architecture defines a number of state bits that define the 
processor context and the operation of instructions. These bits determine operand size (whether 
a given wide form instruction acts on 16 bits or 32), stack size (whether a PUSH or POP 
instruction updates 16 bits or 32 of the stack pointer), address size (whether addresses are 16 or 

10 32 bits), whether the processor is in V86 mode, whether addressing is physical or virtual, the 

floating-point stack pointer, and the full/empty state of floating-point registers. The X86 scatters 
these bits around code and stack segment descriptors, the EFLAGS register, the floating-point 
status word, the floating-point tag word, and other places. The Tapestry machine stores these 
bits in analogs of the X86 structures to actually control the machine; when a Context_At_Point 

15 entry 430 is captured, a snapshot of these bits are captured into bits <59:51> 432, 433 and 
<42:32> 435 of the Context_At_Point entry 430. 

Bits <59:56> 432 indicate the current state of the operand-size/address-size mode 
(encoded in the D bit of the X86 code segment descriptor), and the stack address size (encoded in 
the B bit of the stack segment descriptor). Bit <59>, "clsl," indicates that the X86 is in 32-bit- 

20 code/32-bit-stack mode. Bit <58>, "clsO," indicates that the X86 is in 32-bit-code/16-bit-stack 
mode. Bit <57>, "cOsl," indicates that the X86 is in 16-bit-code/32-bit-stack mode. Bit <56>, 
"cOsO," indicates that the X86 is in 16-bit-code/16-bit-stack mode. (The D and B bits render the 
X86 instruction set ambiguous. For instance, a given nine-byte sequence of the instruction 
stream might be interpreted as a single instruction on one execution, and three entirely different 

25 instructions on the next, depending on the values of the D and B bits. Very few architectures 
share this ambiguity.) Thus, whether or not to profile any particular combination of the four 
possible combinations of D and B modes can be individually controlled. 

In field 433, bit <55>, "pnz," indicates that the X86 is in non-ring-zero (unprivileged) 
mode. Bit <54>, "pez," indicates that the X86 is in X86 ring-zero (privileged) mode. Bits <53>, 

30 <52>, and <5 1>, "v86," "real," and "smm," indicate respectively, that the X86 is in virtual-8086, 
real, and system management execution modes, as indicated by X86 system flag bits.. 
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Bits <50:43>, special_opcode 434, are filled from TAXi_ControLspecial_opcode 474 
whenever a Context_At_Point entry is generated. These bits are especially relevant to event 
code 0.1010. 

In field 435, bits <42:40> are the floating-point top-of-stack pointer. Bits <39:32> are 
5 the floating-point register full/empty bits. 

Field event__code 436, bits <3 1 :28>, contains an event code 402, the four least significant 
bits from the most recently executed RFE or converter event code (from Fig. 4b). The four bits 
of the Context_At_Point event code 436 are the four low order bits of the event code 402 of Fig. 
4b. The high-order bit is derived from these four by a method that will be described in section 
10 V.G, infra. As will be described more fully there, a Context_^At_Point entry 430 can describe 
any of the sixteen events from the upper half 410 of the table, or an event with the "initiate 
packef property 418 from anywhere in the table of Fig. 4b. 

Bits <27:00> describe the next X86 instruction, the instruction about to be executed at the 
time that the Context_At_Point context was snapshotted. Field next_frame 438, bits <27:12>, 
1 5 give a physical page frame number, and field next_byte 439, bits <1 1 :00>, give a 12-bit offset 
into the page. 

Referring to Fig. 4d, aNear_Edge entry 440 describes a completed X86 intra-segment 
"near" control transfer instruction. Bits <63:60> 441 of a Near_Edge entry 440 describe the 
length of the transfer instruction. The length 441 value is between one and fifteen (the shortest 

20 X86 instruction is one byte, and the longest is fifteen bytes). Because a zero length cannot occur, 
these four bits 431 distinguish a Near^Edge entry 440 from a Context_At_Point entry 430. 

The instruction at the source end of the Near_Edge transfer is described by a page frame 
number in which the instruction begins, a page fi-ame number in which the instruction ends, a 
byte offset into the page where the instruction begins, and an instruction length. The page frame 

25 number for the beginning of the instruction is not explicitly represented in the Near_Edge entry 
440, but rather is inherited as the next_frame value 438, 448 from the immediately-preceding 
entry in the profile packet (recall that profile packet always start with a Context At Point entry 
430, and that a Near Edge entry 440 is never the first entry). The page frame in which the last 
byte of the instruction lies is represented in field done_frame 444, bits <59:44>. These two page 

30 frame numbers will differ if the instruction straddles a page boundary. The byte offset into the 
page where the instruction begins is represented in field done_byte 445, bits <43:32>. The 
length is recorded in field donejength 441, bits <63;60>. Thus, the source instruction ends at 
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the byte found by summing (((done_byte 445 + donejength 441) -1) mod 4096) (4096 because 
that is the size of an X86 page). 

The destination of the Near_Edge transfer is described by next frame 448 and next_byte 
449 fields in bits <27:00>, in the manner of the next_frame 438 and next_byte 439 fields, bits 

5 <27:00>5 described supra for a Context_At_Point entry 430. 

Field event_code 446, bits <3 1 :28>, contains an event code, parallel to the event code 
436 of a Context At Point entry 430. The four bits of the Near_Edge event_code 446 are the 
four low order bits of the bottom half of Fig. 4b; a leading One is assumed. (Thus a Near__Edge 
entry 440 can only describe one of the sixteen events in the lower half 404 of Fig. 4b.) 

10 Thus, all physical pages are mentioned in successive profile entries in their execution 

order. When execution crosses fi^om one physical page to another because of an explicit branch, 
the branch is indicated by a Near_Edge entry 440. When execution crosses from one physical 
page to another because of sequential execution in virtual address space across a page boundary, 
a Near_Edge entry 440 will be generated either between the instruction that ended at the end of 

1 5 the page and the instruction that begins the next, or between the instruction that straddles the 
page break and the first full instruction of the next page. Alternatively, if control enters a page 
without a Near Edge event, a Context_At_Point profile entry 430 will describe the arrival at the 
page. Together, these rules ensure that sufficient information exists in the profile entries that the 
flow of execution can be retraced, and a hot spot detected, without reference to the binary text. 

20 Allowing the hot spot detector to operate without examining the instruction text allows it to run 
without polluting the cache. Further, the guarantee that all physical pages are mentioned allows 
for profiling of the program as it exists in the physical memory, even though the X86 executes 
the instructions from the virtual address space. The guarantee ensures that control flow can be 
traced through the physical memory, without the need to examine the program text to infer 

25 adjacency relationships. 

For a Near_Edge entry 440, the X86 processor context on arrival at the destination 
instruction is inferable fi:om fields 432, 433 (bits <59:51>) and 435 (bits 42:32>) of the nearest- 
preceding Context_At_Point entry 430, by starting with the context 432, 433, 435 encoded in 
that Context At Point 430, and tracing forward through the opcodes of the intervening 

30 instructions to capture any updates. 
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D. Profile information collected for a specific example event - a page straddle 

Referring to Figs. 4e and 4f, consider two instances of instructions that straddle a page 

boundary. Figs. 4e and 4f are drawn in virtual address space, though profiler 400 operates in 
physical address space. 

5 In Fig. 4e, consider instruction 450 that straddles a page boundary 451 between pages 

452 and 453, and is not a transfer-of-control instruction. The page-crossing is described by a 
Near_Edge entry 440, 454 with a sequential event code, code 1.1110 (406 of Fig. 4b). The 
instruction begins in the page 452 identified in the next_jS:ame bits (bits <27: 12>) 438, 448, 452a 
of the immediately previous profile entry 455, whether that previous entry is a Context_At_Point 

10 430 or a Near Edge 440. The instruction begins at a byte offset indicated by done_byte 445 (bits 
<43:32>) of current Near_Edge 454. The length of the instruction is indicated in donejength 
441 (bits <63:60>) of current Near_Edge 454. The last byte of the instruction is in page 453, 
indicated by done frame (bits <27:12>) 444, 453a of current Near_Edge 454. The last byte of 
the instruction will fall at byte (((done_byte 445 (bits <43:32>) + donejength 441 (bits 

15 <63:60>) -1 ) mod 4096)), which will necessarily equal ((next_byte 449 (bits <1 1 :00>) - 1) mod 
4096). The first byte of the next sequential instruction 456 falls in page 453, as indicated in 
next_frame 448, 456a (bits <27:12>) of current Near_Edge 440, 454, at byte next_byte 449 (bits 
<1 1 :00>). Because the maximum length 441 of an instruction (fifteen bytes) is less than the 
length of a page, done frame 453a of previous profile entry 455 will necessarily equal 

20 Next_Frame 456a of current Near_Edge 454 in the page-straddling-instruction case shown in 
Fig. 4e. 

If instruction 450 is entirely within page 452 and ends exactly at the page boundary 451, 
and is not a control transfer (or is a control transfer that falls through sequentially), then a 
Near_Edge 440, 454 will be generated whose done_frame 453a will point to page 452, and 

25 whose next_frame 456a will point to the following page. 

Referring to Fig. 4f, consider another example, a page-straddle control transfer 
instruction 450 that touches three pages, the two pages 452, 453 on which the source instruction 
itself is coded, and page 458 on which the destination instruction 457 begins. Event code 446 of 
current Near_Edge entry 454 records the nature of the control transfer, codes 1.0000 through 

30 1.1 100 (Fig. 4b). As in the sequential flow case of Fig. 4e, transfer instruction 450 begins in 
page 452, as indicated identified in next_frame field 438, 448, 452a of immediately previous 
profile entry 455, at a byte offset indicated by next_byte 439 (bits <43:32>) of current 
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Near_Edge 455. The length of instruction 450 is indicated in donejength 441 of current 
Near__Edge 454. Instruction 450 ends in page 453, as indicated by done_frame 444, 453a (bits 
<59:44>) of current Near_Edge 440, 454, at byte ((done_byte 445 (bits <43:32>) + donejength 
441 (bits <63:60>) - 1) mod 4096), each taken from the current Near Edge 440, 454. 
5 Destination instruction 457 begins in page 458, as indicated by next_frame 448, 458a (bits 

<27: 12>) of the current Near_Edge 454, at byte offset next_byte 449 (bits <1 1 :00>). For a page- 
straddhng branch 450, done_frame 444, 453a (bits <59:44>) of current Near^Edge 454 now 
disagrees with the next_frame 438, 448 of the previous entry, because of the page straddle. 
If a profile packet is initiated on a control transfer instruction, the first entry will be a 

1 0 Context_At_Point entry 430 pointing to the target of the transfer instruction. 

Referring to Fig. 4a, the Near_Edge 440 and Context_At_Point 430 entries together 
provide a compact, efficient description of even the most complex control flow, giving enough 
information to allow hot spot detector 122 and TAXi binary translator 124 to work, without 
overwhelming them with an overabundance of information that is not useful for these two tasks. 

1 5 Note that the requirements of hot spot detector 122 and TAXi binary translator 124 are 

somewhat different, so the information in the profile is designed to superset the requirements of 
the two. 

In some embodiments, it may be desirable to record a range as the first byte of the first 
instruction to the first byte of the last instruction. Recording ranges in this manner is particularly 
20 attractive if the architecture has fixed-length instructions. 

E. Control registers controlling the profiler 

Referring to Fig< 4g, the TAXi hardware system is controlled by a 64-bit register called 
TAXi_Control 460. TAXi Control 460 allows fine control over profiling. Because much of the 

25 system is driven by the profile, fine control over profiling gives fine control over the entire TAXi 
system. The various bits allow for enabling and disabling separate pieces of the TAXi 
mechanism, enabling and disabling profiling for code that meets or does not meet certain criteria, 
and timer controls that control rates of certain events. In any code region for which profiling is 
disabled, the TAXi resources will be quiescent, and impose no overhead. 

30 In a typical embodiment, the contents of TAXi^Control register 460 will be written once 

during system initialization, to values determined by system tuning before shipment. In other 
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embodiments, the values may be manipulated on the fly, to adapt to particular systems' usage 
patterns. The one exception is the special_opcode field 434, discussed infra. 

Bit <63>, probe 676 is use to^ enable or disable the probe exception, and will be discussed 
in more detail in connection with probing, section VI, infra. Bit <62>, Profile_Enable 464, 

5 "prof," enables and disables profile trace packet collection and delivery of the profile trace- 
packet complete exception. The probe 676 and Profile_Enable 464 bits will typically be 
manipulated to disable TAXi operation any time the hardware debugging resources are active. 

Bit <61>, tio 820, indirectly controls the TAXi I/O exception, to provide one of the 
guards that implement the safety net introduced at section LD, supra, and described in further 

10 detail in section VIILA, infra. 

Bit <60>, unpr 468, enables and disables the unprotected exception, discussed in section 
I.F, supra. Unprotected exceptions are only raised when profiling on unprotected pages. 

Field 470, bits <59:56> control the code segment / stack segment size combinations that 
will be profiled. Bit <59>, "clsl," enables profiling for portions of the program whose X86 

15 code segment has its 32-bit default operand-size/address-size bit set, and uses a stack in a 
segment whose 32-bit stack bit is set. Bit <58>, "clsO," enables profiling for 32-bit 
operand/address, 16-bit stack segments. Bit <57>, "cOsl," enables profiling for 16-bit 
operand/address, 32-bit stack segments. Bit <56>, "cOsO," enables profiling for 16-bit 
operand/address, 16-bit stack segments. 

20 Bit <55>, "pnz," enables profiling for code in privilege rings one, two, and three (Not 

Equal to Zero). 

Bit <54>, "pez," enables profiling for code in privilege ring zero (Equal to Zero). 

Bits <53>, <52>, and <51>, "v86," "real," and "smm" (with the size and mode controls 
of bits <59:54>, collectively known as the Global__TAXi_Enables bits 470, 472), enable and 
25 disable profiling for code in the virtual-8086, real, and system management execution modes of 
the X86 (these execution modes indicated by system flags and the lOPL field in the X86 
EFLAGS register). If a given X86 execution mode is not supported by TAXi (in the sense that 
TAXi will not attempt to produce translated native Tapestry binaries for code of that X86 mode), 
the system is designed to impose no overhead on code in that mode. Thus, when the 
30 Global_TAXi_Enables 470, 472 bit for a mode is Zero and virtual X86 310 is executing in that 
mode, then execution is not profiled, the profile timer (492 of Fig. 4i) does not run, and the 
profile, unprotected, and probe exceptions are all inhibited. 
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Bits <50:44>, special_opcode 474 are used to set the contents of Context_At_Point 
profile entries 430. X86 emulator 316 sets special__opcode 474 to a desired value. When an RFE 
with event code 0.1010 (Fig. 4b) is subsequently executed, the contents of 
TAXi_Control.special_opcode 474 are copied unmodified into the special_opcode field 434 (bits 
5 <50:44>) of a Context_At_Point event 430. 

Bits <43:38>, Packet_Reg_First 476, and <37:32>, Packet_Reg_^Last 478, specify a 
range of the general registers to be used to accumulate profile trace packets. The first 
Context_At_Point entry 430 of a packet will be stored in the register pointed to by 
Packet_Reg_First 476, then the next entry in register Packet_Reg_First+l, and so on, until the 
10 last entry is stored in Packet_Reg_Last 478. Then a "profile fiiU" exception will be raised (536, 
548 of Fig. 5a), so that the profile registers can be spilled to memory. As shown in Table 1, 
typically Packet_Reg_First 476 will be set to 17, and Packet Reg Last 478 to 31. 

Bits <31:16>, Profile_Timer_Reload_Constant 494, and <15:00> 
Probe_Timer_Reload_Constant 632 (bhs <15:00>) are used to control the rate of profile trace- 
1 5 packet collection and probing respectively. This is fiirther discussed in connection with the 

TAXi_Timers register (490, 630 of Fig. 4i; see the discussion of Fig. 4i infra, and the discussion 
of probing in sections VI.C and VI.D, infra). 

Referring to Fig. 4h, the internal state of the TAXi system is available by looking at a 
register called TAXi_State 480. In the normal running of the system, the TAXi_State register 
20 480 is read-only, though it is read-write during context switching or design verification. 

Bit <15>, "preq" or "Profile Requesf 484, indicates that profile timer 492 has expired 
and posted the request to collect another packet, but either no event has yet been encountered to 
initiate the packet, or profile timer 492 expired while a packet was actively being collected. 

Bit <31>, "pacf or "Profile_Active" 482, indicates that preq "Profile Requesf 484 was 
25 set and that an Initiate Packet event (418 of Fig. 4b) was encountered and a profile packet has 
been initiated and is in progress, but the profile registers are not yet filled. 

The unused bits of the register are labeled "mbz" for "must be zero." 
The "Decoded_Probe_Evenf ' 680 and "Probe__Mask" 620 fields will be discussed in 
section VI, infra, 

30 The "Event_Code_Latch" field 486, 487, bits <12:08>, records a 5-bit event code (the 

event codes of Fig. 4b, or the four-bit events of a Context_At_Point entry 430 of Fig. 4c or 
Near_Edge profile entry 440 of Fig. 4d), as a retrospective view of the last event that was 
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generated in converter 136 or encoded as the immediate field in an RFE instruction (588 of Fig. 
5b). Event Code Latch 486, 487 serves as an architecturally visible place to log the event code 
until the next logical cycle of this process. The four low order bits 486 are supplied by the RFE 
immediate field 588 or four bits from converter 136 (582 of Fig. 5b). The high-order bit 487 is 

5 supplied by context, either One for events from converter 136, or Zero for events from an RFE. 

The "Packet Reg" field 489, bits <05:00>, gives the number of the register into which 
the next profile entry will be written, as a post-increment direct address into the register file. 
When TAXi_State.Packet_Reg 489 exceeds TAXi Control.Packet_Reg_Last 478, profile 
collection is terminated, a Profile Packet Complete exception is raised, and the value of 

1 0 TAXi__State.Packet_Reg is reset to TAXi_ControLPacket_Reg_First 476. 

Referring to Fig. 4i, TAXi_Timers register 490 has two sixteen-bit countdown timers 
492, 630. 

TAXi_Timers.Profile_Timer 492 (bits <31 :16>) counts down at the CPU clock frequency 
when profile collection is enabled as described in the following paragraph. Profile Timer 492 is 
15 an unsigned value that counts down to zero. On expiry, hardware reloads profile timer 492 with 
the value TAXi_Control.Profile_Timer_Reload_Constant (494 of Fig. 4g). ProfiIe_Timer 492 
continually counts down and reloads. The transition to zero is decoded as timer expiration as 
defined in the profile exception state diagram (Fig. 5a). 

Profile collection is enabled, and profile timer 492 runs, when these five conditions are met: (1) 
20 TAXi_Control.Profile_Enable 464 is One, (2) converter 136 is active (PSW.ISA bit 194 

indicates X86, see section II, supra), (3) all bytes of the current instruction have 4K page I-TLB 
entries, (4) all bytes of the current instruction have I-TLB page attributes in well-behaved 
memory (Address space zero, with D-TLB.ASI = Zero, is well-behaved, and the other address 
spaces are assumed to reference non-well-behaved memory) and (5) the machine is currently 
25 executing in a mode enabled in the TAXi_ControLGlobal_TAXi_Enables bits 470, 472 (bits 
<59:51>). When X86 debugging or single-step operation is requested, software clears 
TAXi_Control.Profile_Enable 464 to disable profile collection. 

TAXi_Timers.Probe_Timer 630 (bits <15:00>) is discussed in sections VI.C and VI.D, 

infra, 

30 
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F. The profiler state machine and operation of the profiler 

Referring to Fig. 5a, profiler 400 operates according to state machine 510. The four 

states 512, 518, 530, 542 of state machine 510 are identified by the values of the 
TAXi_State.Profile_Active 482 and TAXi_State.ProfiIe_Request 484 bits. The transitions of 

5 TAXi_State.Profile_Active 482 and TAXi_State.Profile_Request 484 bits, and thus of state 
machine 510, are triggered by timer expiry, profileable events, and packet aborts. Event "pe" 
indicates completion of a profileable event in the execution of the X86 program, one of the 
events enumerated as "profileable" 416 in table of Fig. 4b. Timer expiry is the countdown-to- 
zero-and-reset of timer TAXi_Timers.Profile__Timer 492, as described in connection with Fig. 

10 4i, supra. Aborts are described further infra. 

State 512 is the initial state, with Profile_Active 482 (PA) and Profile_Request 484 (PR) 
both equal to Zero. In state 512, profileable events 416 and abort events are ignored, as indicated 
by the loop transition 514 labeled "pe, ap." When the profile timer 492 expires, 
TAXi State.Profile Request 484 is set to One, which transitions 516 state machine 510 to state 

15 518. 

In state 518, Profile_Request 484 is One and Profile_Active 482 is Zero, indicating that 
the Profile Timer 492 has expired, priming profiler 400 to begin collecting a profile packet. But 
that first profileable event 416, 418 has not yet occurred, so profiling is not yet in active 
progress. In state 518, fixrther timer expirations are ignored (loop transition 520), rather than 
20 queued. Aborts are also ignored (loop transition 520), as there is no profile packet content to 
abort. 

The first entry in a profile packet is always an event with the "Initiate Packet" property 
(418 of Fig. 4b). State 518 waits until the first "initiate packet" pcinu event 418 occurs, initiating 
transition 522. Profileable events (416 of Fig. 4b) that are not "Initiate Packet" events (418 of 

25 Fig. 4b) are ignored, indicated by the "peiiT" label on loop transition 520. On transition 522, 
several actions 524 are initiated. TAXi State.Packet Reg 489 is initialized from 
TAXi_Control.Packet_Reg_First 476. The hardware captures a timestamp from the 
Global_Timestamp processor register into the Packet_Timestamp control register (or, in an 
alternative embodiment, into the general register preceding the first profile event capture 

30 register). A Context_At_Point profile entry 430 is captured into the general register indicated by 
TAXi_State.Packet_Reg 489. At decision box 526, TAXi_State.Packet_Reg 489 is incremented, 
and compared against TAXi_Control.Packet_Reg_Last 478. For the first profile entry, the 
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packet registers will never be full, so control follows path 528. TAXi_State.Profile_Active 482 
is set to One, and TAXi_State.Profile_Request 484 is cleared to Zero, putting state machine 510 
in state 530. 

This first entry in a packet is the only circumstance in which converter 136 can generate a 

5 Context_At_Point entry 430. For second-and-foUowing entries in a profile packet, converter 136 
only generates Near_Edge entries 440. Any subsequent Context_At_Point entry 430 in the 
packet is generated by the RFE mechanism. 

In state 530, Profile_Request 484 is Zero and Profile_Active 482 is One. At least one 
profileable event (416 of Fig. 4b) has been recognized and recorded, a profile packet 420 is in 

1 0 progress, and profiler 400 is awaiting the next profileable event 416. When the next profileable 
event 416 occurs 532, the profileable event is recorded 534 in the general register indicated by 
TAXi_State.Packet_Reg 489. After the event is captured by a TAXi instruction (see discussion 
of Fig* 5b, infra), control reaches decision box 526. If the range of profile registers is not fiiU 
(TAXi State.Packet Reg 489 ++ < TAXi_Control.Packet_Reg_Last 478 - the old value of 

1 5 TAXi_State.Packet_Reg 489 is tested and then TAXi_State.Packet_Reg 489 is incremented), 
then control returns 528 to state 530 to collect more profileable events 416. If the profile 
registers are fiall (TAXi_State.Packet_Reg 489 equals TAXi__Control.Packet_Reg_Last 478), 
then the machine takes a profile exception 536. TAXi_State.Packet_Reg 489 is incremented 
after the comparison. The profile exception handler stores the collected profile into a ring buffer 

20 in memory, along with the timestamp captured by action 524.. The ring buffer write pointer, 
pointing to the next location in the ring buffer, is maintained in R15 ("RingBuf of Table 1). 
After the collected profile packet is stored at the location indicated by R15, R15 is 
postincremented by the size of a profile packet. TAXi_State.Profile_Active 482 and 
TAXi_State.Profile_Request 484 are both cleared to Zero, and control returns 538 to start state 

25 512. 

If TAXi_Timers.Profile_Timer 492 expires while state machine 510 is in state 530, that 
is, while a profile packet was in progress, state machine 510 sets TAXi_State.Profile_Active 482 
and TAXi_State.Profile_Request 484 both to One, and transitions 540 to state 542, 

The behavior of state 542 is largely similar to state 530, in that a partially-complete 
30 packet is in progress, and new profileable events 416 are logged 544 as they occur. The 

difference between states 530 and 542 arises when the packet is complete. A profile-registers- 
full exception 548 from state 542 spills the profile registers to memory, just as profile exception 
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536, but then as part of transition 546, TAXi_State.Profile_Request 484 is set to One, to 
transition to state 518, instead of to Zero as in transition 538, which transitions into start state 
512 to await the next timer expiry 516. From state 518, collection of the next packet can begin 
immediately on the next "initiate packet" event 418, rather than awaiting another timer expiry 

5 516. This effects one level of queuing of pending timer expiries. 

Collection of a profile packet may be aborted 550, 552 mid-packet by a number of 
events. For instance, an abort packet event code is provided (row 0.101 1 of Fig, 4b) - an RFE 
with this event code clears TAXi__State.Profile_Active 482, which in turn discards the current 
profile packet and aborts profile collection until at least the next profile timer expiry. If the 

1 0 predicate for enabling profiling (from the discussion of TAXi_Control 460 in section V.E, supra) 
becomes unsatisfied, then the packet is aborted. For instance, a packet will be aborted if control 
passes to a page that is not well-behaved memory (for instance, a page on the I/O bus), or a byte 
of instruction lies on a page that does not have a 4K page I-TLB entry, or the X86 execution 
mode transitions to a mode for which profiling is not enabled in the 

15 TAXi_ControLGlobaLTAXi_Enables bits 470, 472. This abort protocol 550, 552 assures hot 
spot detector 122 that each packet describes an actual execution path of the X86 machine, 
without omission. 

A transition from X86 code to Tapestry code (for instance, a successful probe exception, 
see section VI, infra) may be an abort 550, 552 event. Profiler 400 is configured to allow the 

20 choice between entirely discarding the aborted packet or padding out and then spilling the partial 
packet to the ring buffer before abort 550, 552 occurs. This choice is implemented in the code of 
the X86-to-Tapestry transition handler 320. 

Fig. 5b is a block diagram of a portion of profiler 400, the logic 554 to collect and format 
a profile entry 430, 440 into a processor register. The inputs to logic 554 include TAXi State 

25 register 480, and a number of lines produced by X86 instruction decode logic 556 within 

converter 136. The output of logic 554 is a profile entry in register 594. Logic 554 as a whole is 
analogous to a processor pipeline, with pipeline stages in horizontal bands of Fig. 5b, 
progressing from the top of the diagram to the bottom. The stages are clocked at X86 instruction 
boundaries 566. Recall from the discussion of Fig. Ic that Align stage 130 parsed the X86 

30 instruction stream, to identify fiill X86 instructions, and the spatial boundaries in the stored form. 
Convert stage 134, 136 further decodes X86 instructions and decomposes the complex X86 
CISC instructions into simple RISC instructions for execution by Tapestry pipeline 120. The 
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temporal division between X86 instructions is marked by a tag 566 on the last instruction of the 
recipe of constituent Tapestry instructions emitted by converter 136. The temporal boundaries 
between X86 instructions are flagged in a bit of the Tapestry PSW, PSW.X86_Completed 566. 
The first native instruction in the converter recipe (which may be a TAXi instruction), resets 

5 PSW.X86_Completed 566 to Zero. The last native instruction in the converter recipe sets 
PSW.X86_Completed to One. If a converter recipe contains only one native instruction, then 
PSW.X86_Completed 566 is set to One. Since an emulator trap is guaranteed to be the last 
instruction in a converter recipe, upon normal completion of an emulated instruction recipe, 
PSW.X86_Completed will be One. 

1 0 The Tapestry processor provides a special instruction for capturing a profile entry from 

processor register 594 into a general register. This special instruction is called the "TAXi 
instruction." The TAXi instruction is injected into the Tapestry pipeline when a profile entry is 
to be captured. Recall from the discussion of Fig. Ic, supra, that converter 136 decomposes each 
X86 instruction into one or more Tapestry instructions according to a "recipe" for the X86 

15 instruction. The TAXi instruction is simply one more Tapestry instruction injected into the 

pipeline under the cooperation of profiler 400 and converter 136. Thus, profile generation is an 
integral part of the basic Tapestry instruction execution cycle. The TAXi instruction is typically 
injected into the pipeline at the beginning of the recipe for the instruction at the destination of a 
control transfer. At the choice of the hardware implementer, the TAXi instruction may be either 

20 a special move instruction not encodeable in the Tapestry instruction set, or it may be a move 
from a processor register. Depending on implementation choice, the instruction can take the 
form of a "move from register 594 to general register TAXi_State.Packet_Reg 489" or converter 
136 can extract the contents of register 594 and inject a move-immediate of this 64-bit datum 
into the profile collection general register specified by TAXi_State.Packet_Reg 489. 

25 Instruction decode logic 556 of the Align and Convert pipeline stages (130, 134, 136 of 

Fig. Ic) produces signals 558-562 describing the current instruction and certain other profileable 
properties of each instruction, and this description is latched. The information generated 
includes the instruction length 558 (which, if the instruction generates a profileable Near_Edge 
event 416, will end up as done Jength 441 (bits <64:61>) of a Near_Edge entry 440), the page 

30 frame for the last byte of the instruction 559 (done_byte 445 (bits <59:44>) of a Near_Edge 
entry 440), and the page frame 560 and byte offset 561 of the first byte of the next instruction 
(bits <27:00>, the next_frame 438, 448 and next_byte 439, 449 of aNear Edge 440 or 
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Context_At_Point 430). Also generated by decode logic 556 is a raw event code 562 associated 
with the X86 instruction when that instruction is executed by converter 136, an indication of 
whether the instruction ends on or straddles a page boundary 563, whether the instruction is a 
control transfer (conditional or unconditional) 584, whether a PC-relative branch is forward or 
5 backward, and whether converter 136 is currently active (which in turn is copied from the PSW) 
590, 

At the next X86 instruction boxmdary 566, the information from the just-completed 
instruction is clocked from signals 558, 559, 561 to registers 568, 569, 570. Registers 568, 569, 
570 are simply a buffer for time-shifting information about an X86 instruction to make it 

10 available during the next instruction, in case a profile event is to be captured. Because the native 
control transfer instruction is always the last instruction of the recipe for an X86 transfer 
instruction, the virtual-to-physical translation of the address of the destination of the transfer 
(especially in the case of a TLB miss) is not available until the transfer instruction itself is 
complete. If an event is to be captured, the TAXi profile capture instruction is injected into the 

1 5 pipeline as the first instruction in the recipe of the destination instruction. Thus, the time shifting 
defers the capture of the profile event until the address translation of the destination is resolved. 
Registers 569, 570 together drive a 28-bit bus 572 with the "done" part (bits <59:32>) of a 
Near_Edge profile entry 430. 

Simultaneously, the X86 processor context for the current X86 instruction is made 

20 available on a 28-bit bus 574, in a form that parallels bits <59:32> of a Context_At_Point entry 
440. 

Event codes are generated by circuits 576, 591, and used to control capture of profile 
entries, as follows. 

X86 instruction decode logic 556 generates a new raw event code 562 for each X86 
25 instruction. This event code designates a control transfer instruction (event codes LOOOO - 
1.1011 of Fig. 4b), an instruction that straddles or ends on the last byte of a page frame (code 
1 . 1 1 1 1 , 408 of Fig. 4b), or the default converter event code ( 1 . 1 1 1 0, 406 of Fig. 4b) for all other 
cases. (For instructions executed in emulator 316, as converter 136 parses the instruction, logic 
576, 578 generates the defauh event code 1 . 11 1 0 406 or page-straddle event code 1.1111 408, 
30 and then this raw event code 562 is overwritten or selected by the event code immediate field 
588 of the RFE instruction at the end of the X86 instruction's emulation routine.) 
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If the instruction is not a control transfer instruction, the two special "non-event" event 
codes 1.1110 406 and 1, 1 1 1 1 408 (sequential flow or page straddle) are manufactured by circuit 
578, using the "straddles a page boundary" signal 563 to set the low-order bit. 

MUX 580 generates final converter event code 582, selecting between the raw event code 
5 562 generated by instruction decode logic 556 and the 1 .1 1 Ix non-event event code 406, 408 
from circuit 578 by the following mechanism. If the current instruction is a "control transfer" 
(either an unconditional or a conditional transfer) as indicated by line 584, or the branch 
predictor predicts 586 that the branch is taken, then MUX 580 selects the raw event code 562 
generated by decode logic 556, else MUX 580 selects the non-event event code from 1.1 1 Ix 
10 circuit 578. 

When the branch is predicted 586 taken, MUX 580 selects the raw conditional branch 
event code 562 associated with the instruction. When the branch is predicted 586 not taken, 
MUX 580 selects the 1 . 1 1 Ix non-event event code (either the page boundary event code 1.1111 
408 or the default event code 1.1110 406) from circuit 578. Recall that the native control 

1 5 transfer instruction is always the last instruction of the recipe for an X86 transfer instruction, and 
that the TAXi profile capture instruction is injected into the pipeline as the first instruction in the 
recipe of the destination instruction of a profileable transfer. Thus, if it turns out that the branch 
prediction 586 was incorrect, the entire pipeline (120 of Fig. Ic) downstream of converter 136 is 
flushed, including the TAXi instruction that would capture the contents of register 594 into the 

20 next general register pointed to by TAXi_State.Packet_Reg 489. (This is because the TAXi 

instruction is injected into the pipeline following the native branch instruction that ends the X86 
recipe.) The instruction stream is rerun from the mis-predicted branch. The branch prediction 
line 586, on rerun, will be asserted to the correct prediction value, and MUX 580 will thus select 
the correct event code, and the TAXi instruction will correctly be injected or not injected. This 

25 event code resolution allows the profile packet to correctly record taken branches or taken 

conditional branches that straddle (or end on) a page boundary, and to correctly omit capture of 
not-taken branches that do not cross a page boundary. 

For emulated instructions, converter 136 always supplies an event code 582 that is either 
the default or new page event code 578. Since converter 136 completely decodes all instructions, 

30 it could supply the event code corresponding to far control transfer instructions (far CALL, far 
JMP, far RET or IRET) instead of the default or new page event code 578. This event code is 
latched as part of the emulator trap recipe. When emulator 316 completes an instruction that 

Atty. Docket No. 30585/28 1 06 Express Mail Label EI465234796US 

NYDOCS04/ 285781 



straddles a page frame and RFE's back to converter 136 with the simple X86 instruction 
complete event code 0.0001, the new page event 1.1111 408 in Event Code Latch (486, 487, 
bits <44:40> of Fig. 4i) will be used. Since the high-order bit is set, a reuse event code 414 RFE 
will result in aNear Edge profile entry being captured; this is correct, because the RFE implies 
5 no data-dependent alteration of context that would require a Context__At_Point. If emulator 316 
supplies an RFE event code that doesn't reuse 414 the Event_Code_Latch, then the RFE event 
code 588 will be latched. This convention allows the profile packet to record either interesting 
emulated instructions or simple emulated instructions that straddle a page frame. 

Similarly, if an X86 instruction fails and must be restarted, the profile information 558, 

10 559, 560, 561, 562, 563, 584 for the instruction is regenerated and runs down the profile pipeline 
554 in parallel with the instruction. For instance, if an instruction fetch misses in the TLB, the 
TLB miss routine will run to update the TLB, and the instruction will be restarted with 
regenerated profile information in the profile pipeline. 

When an event code comes fi^om the immediate field 588 of an RFE instruction (410 of 

1 5 Fig. 4b), Converter Active line 590 is used both as the select line 590a into MUX 591 to select 
between the converter event code 582 and the RFE-immediate event code 588 for the four low- 
order bits, and also supplies the high-order bit 590b of the event code 402, to form a five-bit 
event code 592. This event code 592 is latched into TAXi_State.Event_Code_Latch (486, 487, 
bits <44:40> of Fig. 4i). (The reader may think of TAXi_State.Event_Code_Latch 486, 487 as 

20 being part of the pipeline stage defined by registers 568, 569, 570.) Not shown in Fig. 5b is the 
effect of "reuse event code" 414 of Fig. 4b: when an RFE instruction completes with a "reuse 
event code" event code immediate (0.0000 through 0.001 1), update of 
TAXi_State.Event_Code_Latch 486, 487 is suppressed, and the old event code is left intact. 

Each X86 instruction materializes either a Context_At_Point entry 430 or a Near Edge 

25 entry 440 into 64-bit register 594. The two possible sets of bits 568, 572, 574 are presented to 
MUXes 596a, 596b, and bit TAXi_State.Event_Code_Latch<4> 487 selects between them. 
Note, for instance, that TAXi_State.Profile_Active 482 must be True (states 530 and 542 of Fig. 
5a) in order to generate a One from AND gate 598 to generate a Near_Edge entry 440; this 
enforces the rule that a Near_Edge entry 440 must always be preceded by a Context_At_Point 

30 entry 430. Thus, a Context_At_Point entry is always forced out if TAXi_State.Profile_Active 
482 is Zero (states 512 and 518 of Fig. 5a) when a TAXi instruction is issued. 
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If profiler 400 decides that the entry in register 594 ought to actually be captured into a 
profile, converter 136 injects a TAXi profile capture instruction into the Tapestry pipeline 120 at 
the boundary 566 between the profiled X86 instruction and the next X86 instruction, in order to 
capture the profile information from register 594. 
5 In some embodiments, it may be desirable to inject multiple TAXi instructions to capture 

different kinds of profile information. For instance, multiple TAXi instructions could capture a 
timestamp, a context (analogous to a Context_At_Point entry 430), a control flow event 
(analogous to a Near_Edge entry 440), or one injected instruction could compute the desired 
information, and the next instruction store that information to memory. It may be desirable to 

1 0 temporarily collect the profile information into a register that is not addressable in the 

architecture, to reduce contention for the storage resource. While register conflict scheduling 
hardware would have to be used to schedule access to this temporary register, the addition of this 
register would isolate the operation of profiler 400 fi*om other portions of the processor. 

The TAXi instruction is injected (and a "pe" event 416 triggers a transition in state 

15 machine 510 of Fig. 5a) when all of the following conditions are met: (1) the machine is 

currently executing in a mode enabled in the TAXiControl bits <53;51> (that is, the AND of the 
current X86 instruction context and TAXi_Control.Global_TAXi_Enables 470, 472 is non-zero), 
(2) the machine is at an X86 instruction boundary, (3) all bytes of the current instruction have 4K 
page I-TLB entries, (4) all bytes of the current instruction have well-behaved (address space 

20 zero) memory I-TLB entries, and (5) at least one of these is true: (a) profile collection is enabled 
(TAXi_State.Profile_Active 482 is One) and TAXi_State.Profile__Request 484 is One and 
TAXi_State.Profile_Active 482 is Zero and the event code currently latched in 
TAXi_State.Event_Code Latch 486, 487 has the "initiate packet" property (418 of Fig. 4b), or 
(b) TAXi_State.Profile_Active 482 is One and the event code of TAXi_State.Event_Code_Latch 

25 486, 487 is "profileable" (416 in Fig, 4b), or (c) a TAXi probe exception will be generated (this 
is ancillary to profiling, but rather is a convenient mechanism to control probing, see sections 
VLC and VI.D, infra). 

During an interrupt of the orderly execution of X86 instructions, for instance during a 
TLB miss, page fault, disk interrupt, or other asynchronous interrupt, the machine queries X86 

30 converter 136 and switches to native execution. During native execution, X86 instruction- 
boundary clock 566 is halted. Because X86 clock 566 is halted, the Near_Edge state of the 
previous X86 instruction is held in registers 568, 569, 570 until X86 execution resumes, 
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Note that in the embodiment of Fig, 5b, profiHng is only active during X86 execution. In 
an alternative embodiment, profiler 400 is active during execution of native Tapestry instructions 
translated from X86 by TAXi translator 124, so information generated by profiler 400 can be fed 
back to the next translation to improve optimization the next time the portion is translated. The 
5 register usage of the Tapestry program is confined by the compiler, so that the profile entries can 
be stored in the remaining registers. 

TAXi_ControLProfile_Timer_Reload_Constant (494 of Fig. 4g) can be tuned by this 
method. If hot spot detector 122 finds a that the working set of the program is changing slowly 
(that is, if a high proportion of hot spots detected overlap with previously-detected hot spots), 
10 then profiler 400 is running too often. In this case, Profile_Timer_Reload_Constant 494 can be 
increased, reducing the frequency of profiling. Similarly, if hot spot detector 122 is finding a 
large change in the working set between hot spot detector runs, then 
Profile_Timer_Reload_Constant 494 can be reduced. 

An alternative tuning method for TAXi_ControLProfiIe_Timer_Reload_Constant 494 
15 considers buffer overruns. When the range of profile collection registers is fiiU, the profile 

registers are spilled (536 and 548 of Fig. 5a) to a ring buffer in memory. The hot spot detector 
122 consumes the profile information from this ring buffer. If profiler 400 overruns hot spot 
detector 122 and the ring buffer overflows, then the value in 

TAXi_Control.Profile_Timer_Reload_Constant 494 is increased, to reduce the frequency at 
20 which profiling information is collected. Alternatively, on a buffer overrun, the frequency at 
which hot spot detector 122 runs can be increased. 

G. Determining the five-bit event code from a four-bit stored form 

Referring again to Figs. 4b, 4c, and 4d, the event code field 436, 446 in a profile entry 

25 (either a Context_At_Point entry 430 or a Near Edge entry 440) is four bits. Because the four 
bits can only encode sixteen distinct values, and thirty-two classes of events are classified in Fig. 
4b, the high order bit is recovered as follows. 

A Near_Edge entry 440 can never be the first entry in a packet. The elided high-order bit 
is always a One, and thus a Near^Edge entry 440 always records an event from the lower half 

30 404 of the table of Fig. 4b. The event was always generated by converter 136 (or 1.1 llx non- 
event circuit 578), and was materialized at line 582 of Fig. 5b. 
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When a Context__At_Point 430 is not the first entry in a packet, the elided high-order bit 
is always a Zero, reflecting an event from the upper half 410 of the table of Fig. 4b. These non- 
initial Context_At_Point entries 430 were always generated by RFE events. 

Every packet begins with a Context At Point entry 430, and that Context_At_Point is an 
5 event with the "initiate packet" property (418 of Fig. 4b). The event codes 402 are carefully 
assigned so that only one RFE event code (lower half 404 of Fig. 4b) and converter event code 
(upper half 410 of Fig. 4b) both share identical low-order four bits and are also have the "initiate 
packet'' property 418, These two are event codes 0.01 10 and 1 ,0110, near RET and far RET. 
Thus, the high-order fifth bit can be recovered from the four bit event code 436, 446 of the first 
1 0 event in a packet by a lookup: 



0000 


->1 


1000 


->0 


0001 


->1 


1001 


->0 


0010 


-> 1 


1010 


-> 1 


0011 


-> 1 


1011 


->1 


0100 


-> 1 


1100 


->0 


0101 


-> 1 


1101 


->0 


0110 


-> * 


1110 


->0 


0111 


-> 1 


1111 


->0 



Near and far returns (0.01 10 and 1.01 10) share the same four low-order bits, and either may 
20 appear at the beginning of a packet. An implementation may choose to recover either a 0 or 1 . 
The ambiguity is an acceptable loss of precision. 

H. Interaction of the profiler, exceptions, and the XP protected/unprotected 
page property 

25 Exceptions interact with profile collection in several ways. 

A first class of exceptions are handled completely by the Tapestry Operating System (312 
of Fig. 3a). These include TLB, PTE, and PDE exceptions and all native-only exceptions. After 
handling the exception, sequential execution resumes, with no profile entry collected. The RFE 
instruction at the end of these exception handlers uses the sequential 0.0000 unchanged event 

30 code. 

A second class includes TAXi profiling exceptions, including the profile-register-full 
exception and unprotected exception (see section I.F, supra). Exceptions in this second class 
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have special side effects defined by the TAXi environment. These exceptions resume instruction 
execution and use special RFE event codes to control the profiling environment. 

A third class includes all emulator traps from converter 136 for X86 instruction 
emulation. Exceptions in the third category provide additional profile information. Emulator 316 
5 always uses a non-zero RFE event code to resume converter operation. 

A fourth class includes asynchronous X86 transfers of control from hardware interrupts, 
page faults, breakpoints, single-step, or any other X86 exception detected in converter 136 or 
emulator 316 that must be manifest to the X86 virtual machine. Exceptions in the fourth class 
have special capabilities. When emulator 316 is about to cause a change of control flow through 
10 the X86 IDT, it uses one of four software defined event codes in the RFE. These event codes are 
divided into two categories. One category is used just for profiling and the other is used to allow 
emulator 316 to force a check for translated code on any X86 code page. Emulator 316 maintains 
a private data structure to test that a probe check should be generated for a particular ISR 
address. 

15 The "unprotected" exception (see section I.F, supra) and profiler 400 interact as follows. 

One of the effects of an unprotected exception is to issue a TAXi instruction to start a new 
profile packet. Recall that the unprotected exception is triggered when an X86 instruction is 
fetched from an unprotected, profileable page: 

TAXi_State.Profile_Active 482 = = 1 // profiling 

20 TAXi_Control.unpr 468 = = 1 // exception enabled 

Page's I-TLB.ISA 182 - - 1 and XP 186 = = 0 // unprotected 
Fetch page is 4KB // no abort... 

Fetch page is ASI ~ - 0 //no abort... 

TAXi_State.Profile_Active 482 is set to prime the collection of a packet in the cycle when an 
25 "initiate packet" (418 in Fig, 4b) event is recognized. A TAXi instruction is sent flowing down 
the pipe to update TAXi State.Profile_Active 482 in the following cycle, after the translated 
fetch address is knovm and the next instruction has been successfiilly fetched. A TAXi 
instruction is issued when TAXi_State.Profile_Active 482 is clear, TAXi State.Profile Request 
484 is set and TAXi_State.Event_Code_Latch 486, 487 contains an event^code for which 
30 Initiate_Packet 418 is true or the first instruction in a converter recipe is issued and 

TAXi_State.Profile_Active 482 is set. The unprotected exception handler may choose whether 
to preserve or discard the current profile packet, keeping in mind that profile collection on any 
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page that is not protected is imsafe, since undetected writes to such a page could lead to an 
incorrect profile database. When TAXi Control.unpr 468 is clear, no exception is generated and 
TAXi software is responsible for validating the profile packet and setting the "Protected" page 
attribute. 

5 There are two narrow exceptions to the rule that all pages referenced in a profile packet 

must be protected - the boundary cases at the beginning and end of the packet. If a profile 
packet {e,g., 420 of Fig, 4a) ends with a control transfer instruction, the last byte of the transfer 
instruction, and thus the source of the transfer (the done_frame member 444), must be on a 
protected page, but the destination of the transfer (the next_frame member 438, 448 of the entry) 
1 0 need not be. Similarly, if a packet begins with a control transfer instruction (one having the 

"initiate packef property, 418 of Fig. 4b), the destination of the transfer (next_frame 438, 448) 
must be on a protected page, but the source need not be. In the latter case, the source will escape 
mention in the profile packet as a matter of course, because a packet must begin with a 
Context At Point entry (430 of Fig. 4c), which does not mention the source of the event. 

15 

I. Alternative embodiments 

To provide a good heuristic for when to generate optimistic out-of-order code and when 
to generate conservative in-order code, profile entries may record references to non- well- 
behaved I/O space. One mechanism is described in section VIII.B, infra^ converter event code 

20 1 .1100 that records accesses to I/O space. In an alternative embodiment, a "profile I/O 

reference" exception traps into Tapestry operating system 312 on a reference to I/O space, when 
executing from an X86 code page (PSW.ISA 194 equals One, indicating X86 ISA), and 
TAXi State.Profile Active (482 of Fig. 4h) is One. At the completion of the exception handler, 
the RFE immediate field (588 of Fig. 5b) will supply a profile event with event code 1.1 100 to 

25 indicate an I/O space reference. 

A profile control register may be used to control profiling at a finer grain level. For 
instance, a register may have 32 bits, where each bit enables or disables a corresponding one of 
the event classes of Fig. 4b. Another control for profiling is discussed infra, in connection with 
PLA 650. 

30 
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VI. Probing to find a translation 
A. Overview of probing 

Profiler 400 generates a profile of an X86 program. Hot spot detector 122 analyzes the 
profile to identify often-executed sections of code. TAXi binary translator 124 translates the hot 

5 spot from X86 code to TAXi code (the Tapestry native code generated by TAXi binary translator 
124, functionally equivalent to the X86 binary). Because the X86 binary is left unaltered, it 
contains no explicit control flov^ instruction to transfer control to the TAXi code. "Probing" is 
the process of recognizing v^hen execution has reached a point in an X86 binary that has a 
corresponding valid entry point into TAXi code, seizing control away from the X86 binary, and 

10 transferring control to the TAXi code. 

In one embodiment, each instruction fetch cycle queries of a table. Each entry of the 
table maps an X86 physical IP value to an address of a TAXi code entry point. For instance, a 
large associative memory may map X86 physical IP values to entry points into TAXi code 
segments. The number of segments of TAXi code will typically be, at most, on the order of a 

1 5 few hundred, and execution can only enter a TAXi code segment at the top, never in the middle. 
Thus, only a few hundred entries in the mapping will be live at any point in time. Such a sparse 
mapping can be implemented in an associative memory roughly the size of one of the caches. 
Again, the hit rate in this table will be extremely low. Conceptually, the other embodiments 
discussed infra seek to emulate such an associative memory, using less chip real estate. 

20 In another embodiment, the mapping from X86 physical IP value to Tapestry entry point 

is stored in memory in a table, and the most-accessed portions of this mapping table are kept in a 
cache, analogous to a TLB. Each entry in this mapping table has a valid bit that tells whether the 
accompanying entry is or is not valid. The cached copy of this table is queried during each 
instruction fetch cycle. Again, the hit rate in this table will be extremely low. 

25 In another embodiment, a bit vector has a bit corresponding to each byte (or each possible 

instruction beginning, or each basic block) that indicates whether there is an entry point to TAXi 
code corresponding to that byte of X86 instruction space. Each entry in a mapping table includes 
a machine state predicate, indicating the X86 machine state assumptions that are coded into the 
TAXi code associated with the entry, and the address for the TAXi entry point. In this 

30 embodiment, probing is implemented as a three step process: query the bit vector to see if a 

mapping translation exists, and if so, look in the mapping table, and if that succeeds, verify that 
the X86 machine state currently satisfies the preconditions listed in the table entry. The bit vector 
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is quite large, potentially taking 1/9 of the entire memory. Further, the bit vector and table 
queries tend to pollute the cache. In this embodiment, an exception is raised after the bit vector 
query succeeds, and the table query is performed by the exception handler software; thus, an 
exception is only raised for addresses that have their corresponding bits in the bit vector set, 
5 addresses that have valid TAXi code entry points. 

In another embodiment, each bit in the bit vector corresponds to a page of X86 code. If 
there is an X86 instruction somev^here on the page v^ith a corresponding translation, then the 
corresponding bit in the bit vector is set. Then, at each event that may be followed by entry to a 
TAXi code segment, the mapping table is probed to see if such a translation exists. Thus, this 

10 implementation takes less memory to hold the bit vector than the embodiment of the previous 
paragraph, but generates an exception for every instruction fetch from the pages to query the 
table, not just the instructions that have corresponding TAXi entry points. This embodiment 
works especially well if translation is confined to a relatively small number of infrequent events, 
for instance, subroutine entries, or loop tops. 

15 A bit associated with a page can be cached in the TLB, like the other page properties 180, 

186. 

In the embodiment discussed at length in the following sections, TAXi divides the 
possible event space by space (pages), time (using the Probe timer), and event code (the same 
event code 402 used in profiling). 

20 

B. Overview of statistical probing 

TAXi prober 600 uses a set of statistical heuristics to help make a profitable set of 
choices about when a TAXi translation is highly likely to exist in the TAXi code buffer. Rather 
than probe for a translation on every occurrence of an event, for instance at every routine call, 

25 TAXi prober 600 probes on a larger class of events, including simple control transfers, 

conditional jumps, near CALL, far CALL and delivery of an X86 interrupt, and uses a statistical 
mechanism to throttle the number of probes on the expanded number of classes down to a 
number likely to succeed. The statistical probe mechanism is designed to have a high correlation 
between probe exceptions and actual opportunities to execute TAXi code. 

30 TAXi divides the space of possible program events spatially, logically, and temporally, 

and then forms a statistical association between the X86 code space/logic/time that is not always 
correct, but that is well correlated with the existence of TAXi code. As in the embodiments 
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described in section VI. A, a table maps X86 physical IP values to entry points in TAXi code 
segments. This table is called the PIPM (Physical IP Map) 602. Each physical page has 
associated properties. The properties are associated with several logical event classes (a subset 
612 of the event classes laid out in Fig. 4b and discussed in section V.B, supra). Binary 
5 translator 124 maintains five bits 624 of properties per page in PFAT (page frame attribute table) 
172 - when a binary translation is created, the bit 624 corresponding to the entry event is set in 
the X86 page's PFAT entry 174 to indicate the existence of the translation, and an entry in PIPM 
602 is created that maps the X86 physical IP address to the address of the TAXi code segment. 
The five PFAT bits are loaded into the TLB 116 with the page translation from the page tables. 

10 Enablement of the feature that queries these bits is gated by a time-varying probe mask, whose 
bits correspond to the five PF AT/TLB bits. 

A probe occurs in several stages, as will be described in detail in connection with Fig. 6c. 
When a stage fails, the rest of the probe is abandoned. The first stage is triggered when an X86 
instruction is executed, and that instruction generates an event code that is one of the probeable 

15 event codes, and the corresponding probe property for the page is enabled, and the corresponding 
bit in the current probe mask is enabled. The first stage is essentially an implementation of the 
associative memory search described for the previous embodiments, but on a memory page 
granularity. This first stage gives a reasonable-but-imperfect evaluation of whether it is likely to 
be profitable to generate an exception, so that software can actually probe PIPM 602. If this first 

20 stage test succeeds, then the processor generates a probe exception. A software exception 
handler probes PIPM 602 to discover whether there is a current translation of the current IP 
value, and to find the address of that translation. 

This implementation uses no large hardware structures on the Tapestry microprocessor 
chip; for instance, it avoids a large associative memory. The implementation reduces the 

25 overhead associated with unsuccessful probes of PIPM 602, while providing a high likelihood 
that execution will be transferred to the TAXi code that is translated to replace a hot spot of the 
X86 program. 

Recall also that probing is an optimization, not a condition for minimum correctness. If 
prober 600 generates too many probe exceptions, the excess probes of PIPM 602 will fail 
30 because there is no translation to which to transfer control, and correct execution will resume in 
converter (136 of Figs, la and Ic). The cost of an error is one execution of the probe exception 
handler. If the mechanism generates too few probes, then control will not be transferred to the 
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TAXi code, and execution will simply continue in converter 136. The cost of the error is the 
opportunity foregone (less the cost of the omitted exception). Because errors do not induce any 
alteration in the result computed, a heuristic, not-always-correct approach does not violate any 
architectural correctness criteria. This goal is sought by finding fine-grained ways of slicing up 
5 time, space, and classes of events, and associating a well-correlated indicator bit with each slice. 

C. Hardware and software structures for statistical probing 

A number of the structures discussed in section V, supra, in connection with profiling are 

also used in probing. 

10 Referring again to Fig. 4b, the event code taxonomy 402 for profiling is also used for 

probing. Column 610 designates a number of events as "probeable." The events designated 
probeable 610 are all transfers of control by an X86 instruction or interrupt. The code at the 
destination of the transfer is a candidate for a probe. Hot spot detector 122 is designed with 
knowledge of the probeable event classes, and will only translate a detected X86 hot spot when 

15 the control transfer that reaches the hot spot is one of the probeable events 610. Thus, when an 
X86 program executes a transfer of control, and the transfer is one of the probeable 610 transfers, 
there is at least the theoretical possibility of the existence of TAXi code, and the rest of the probe 
circuitry is activated. 

The probeable events 610 are further classified into six classes, in column 612. The six 
20 classes are "far CALL," "emulator probe," "jnz," "conditional jump," "near jump," and "near 
CALL." 

Referring again to Fig. 4h, probe mask 620 is a collection of six bits, one bit 
corresponding to each of the six probeable classes 612 of Fig. 4b. When a probe mask bit is 
One, probes for the corresponding class 612 are enabled - when an event of that class occurs 
25 (and certain other conditions are satisfied, see the discussion of Figs. 6a-6e, infra), the hardware 
will trigger a probe exception and a probe of PIPM 602. When a probe mask 620 bit is Zero, 
probes for the corresponding class 612 are disabled - even if a translation exists for the 
destination of the event, the hardware will not initiate a probe of PIPM 602 to find the 
translation. 

30 Referring again to Fig. Id, a PFAT entry 174 has five bits 624 of properties for each 

physical page. These five bits 624 correspond to the "far CALL," "jnz," "conditional jump," 
"near jump," and "near CALL" probeable properties (612 of Fig. 4b, 620 of Figs. 4h and 6b, and 
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660, 661, 662, 663, 664 of Fig. 6b - the "emulator probe" probe is raised by software, rather 
than being maintained on a per page basis). The corresponding bit of PFAT probe properties 624 
is set to One when hot spot detector 122 has detected a hot spot and binary translator 124 has 
generated a native Tapestry translation, and the profile for the translation indicates the class of 

5 events that lead to entry of the X86 hot spot that is detected and translated. The five bits 624 of a 
given page's PFAT entry are AND'ed together with the five corresponding bits of probe mask 
620 to determine whether to probe, as described infra in connection with Figs. 6b-6c. 

Referring again to Figs. 4g, 4h and 4i, TAXi_Timers.Probe_Timer 630 is an unsigned 
integer countdown timer that counts down at the CPU clock frequency, used to control the 

10 average rate of failed probe exceptions on a per-event-class basis. When Probe_Timer 630 

counts down to zero, TAXi_State.Probe_Mask 620 is reset to all One's, and Probe_Timer 630 is 
reset to the value of TAXi_Control.Probe_Timer_Reload_Constant 632. An RFE with event 
code 0.001 1 forces an early reset of Probe_Timer 630 from Probe_Timer_Reload_Constant 632. 
Together, ProbeJMask 620 and Probe Timer 630 synthesize the following behavior. As 

15 long as probes of a class 612 are successful, the machine continues to probe the class. When a 
probe fails, the class 612 of the failed probe is disabled for all pages, by setting the class' bit in 
Probe_Mask 620 to Zero. At the next expiry of Probe_Timer 630, all classes are re-enabled. 

Recall that TAXi code segments are created asynchronously to the execution of the X86 
binary, after a hot spot is detected by hot spot detector 122. Translated code segments are retired 

20 when they fall into disuse. On a round-robin basis, TAXi native code segments are marked as 
being in a transition state, and queued as available for reclamation. The code segment, while in 
transition state, is removed from all address spaces. If the TAXi code segment is invoked while 
in transition state, it is dequeued from the transition queue, mapped into the invoking address 
space, and re-set into active state. If the TAXi code segment is not invoked while in transition 

25 state, the storage is reclaimed when the segment reaches the tail of the queue. This reclamation 
policy is analogous to the page replacement policy used in Digital's VAX/VMS virtual memory 
system. Thus, because the reclamation policy is somewhat lazy, PFAT 172 may be somewhat 
out of date. 

Referring to Fig. 6a in conjunction with Figs. Ic, Id, 3a and 4b, PIPM 602 is a table of 
30 PIPM entries 640. Each PIPM entry 640 has three classes of information: the X86 physical 
address 642 that serves as an entry point into a translated hot spot, X86 machine context 
information 646, 648 that was in effect at the time of previous executions and which now serves 
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as a precondition to entry of a translated TAXi code segment, and the address 644 of the 
translated TAXi code segment. The integer size and mode portion 646 of the context 
information is stored in a form that parallels the form captured in a Context_At_Point profile 
entry (430 of Fig. 4c), and the form used to control profiling in the 
5 TAXi_Control.GlobaLTAXi_Enables bits (470, 472 of Fig. 4g). If the current size and mode of 
virtual X86 310 does not match the state saved in the size and mode portion 646 of PIPM entry 
640, the probe fails. The floating-point portion 648 of PIPM entry 640 parallels the floating- 
point state 435 captured in a Context_At_Point profile entry 430. If, at the conclusion of an 
otherwise successful probe, the floating-point state of virtual X86 310 does not match the state 

10 saved in the floating-point portion 648 of PIPM entry 640, then either the floating-point state is 
massaged to match the state saved in PIPM entry 640, 648, or the probe fails. 

Referring to Fig. 6a in combination with Fig. lb, PIPM 602 is kept up-to-date, reflecting 
the current catalog of translations available, and tracking TAXi code translations as they are 
created, marked for reclamation, and actually reclaimed and invalidated. The probe bits in PFAT 

15 172 may lag slightly, and the probe bits in TLB 116 are allowed to lag slightly further. Further, 
the probe bits in TLB 116 only convey information to page granularity. Thus, the probe bits in 
TLB 116 indicate that at some recent time there has been TAXi code with that entry point class 
on this page. A Zero bit in TLB 116 suggests that there is no such entry point, and that a probe 
of the PIPM 602 on this event class would very likely fail, and thus should not be attempted. A 

20 One suggests a high likelihood of success. The One may be somewhat stale, still indicting the 
presence of a TAXi code translation that has since been invalidated and reclaimed. After a hit in 
TLB 116, a probe of PIPM 602 will find that the PIPM entry 640 for the reclaimed TAXi code 
segment will indicate the invalidity of the TAXi segment, for instance, by a Zero in address 644. 
Recall from section V.G, supra, that a fifth high-order bit is needed to disambiguate the 

25 four-bit event code stored in TAXi_State.Event_Code_Latch 486, 487 and Context At Point 
profile entries 430. The event codes 402 of Fig. 4b are carefully assigned so that no probeable 
610 RFE event code (top half 410) shares four low-order bits with a probeable 610 converter 
event code (bottom half 404). Probeable 610 RFE events 410, 610 are always even, and 
probeable 610 converter events 404 are always odd. Thus, the least significant four bits of the 

30 current event code uniquely identify the probe event, the probe exception handler can always 
determine whether the probe event came from a RFE instruction or converter execution. (This 
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non-overlap of probeable events 610 is an additional constraint, on top of the non-overlap of 
"initiate packet" event codes 418 discussed in section V.G, supra.) 

Referring again to Fig. 6b, probing is controlled by a PLA (programmable logic array) 
650 and several AND gates. PLA 650 generates several logic fiinctions of event code 592 from 
5 event code latch 486, 487. PLA 650 computes the "initiate packef ' 418, "profileable event" 416, 
and "probeable event" 610 properties as described in Fig. 4b. In addition, the probeable event 
codes are decoded into single signals as described in column 612 of Fig, 4b. For instance, "jnz" 
bit 660, corresponding to bit <0> of the probe properties 624 of Fig. Id, is asserted for event 
code 1 .0001 . "Conditional jump" bit 661, corresponding to bit <1> of probe properties 624, is 
10 asserted for event code l.OOH . "Near jump" bit 662, corresponding to bit <2> of probe 

properties 624, is asserted for event code 1 .0101. "Near CALL" bit 663, corresponding to bit 
<3> of probe properties 624, is asserted for event codes LO 1 1 1 and L 1 0 1 1 . "Far CALL" bit 
664, corresponding to bit <4> of probe properties 624, is asserted for event code 0.1000. 
"Emulator probe" bit 665 is asserted for event codes 0.1 100 and 0.1 1 10. 

15 

D. Operation of statistical probing 

Referring to Figs, 6b and 6c, for an X86 transfer of control instruction (either a simple 
instruction executed in converter 136 or a complex instruction executed in emulator 316), the 
instruction fetch of the transfer target ensures that TLB 116 is updated from PFAT 172 with the 

20 current probe page properties 624 for the page of the target instruction - either the information 
was already current in TLB 116, or it is refilled as part of the I-TLB miss induced by the 
instruction fetch. Thus, as part of the instruction fetch, the TLB provides both an address 
translation and the probe page properties 624 for the target instruction (though, as discussed in 
section VLC, supra, the probe properties in TLB 116 may be slightly stale). 

25 Further, these control transfer instructions generate an event code 402, as described in 

section V.F, supra. At the conclusion of the instruction, either converter 136 or an RFE 
instruction generates a 5-bit event code 592. The event code is stored in latch 486, 487. As the 
target instruction is fetched or begins execution, event code latch 486, 487 is fed to PLA 650. 

Six 3-input AND gates 670 AND together the probeable event signals 660, 661, 662, 663, 

30 664, 665 with the corresponding page properties from the TLB (624 of Fig. Id) and the current 
value of ProbeJMask 620. The six AND terms are OR'ed together in OR gate 672. Thus, the 
output of OR gate 672 is One if and only if the current instruction generated an event 592 whose 
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current Probe_Mask 620 is One and whose probe property bit 624 for the current page is One. 
The "emulator probe" signal 665 is generated by PLA 650 when RFE event code equals 0.1 100 
or 0,1 110, as indicated by "Emulator Probe" in column 612 of Fig. 4b. This class of probe is 
raised when emulator 316 believes that probe success is likely and the Emulator Probe bit (bit 

5 <5>) of Probe Mask 620 is One. 

The sum of OR gate 672 is AND'ed 674 with several more terms. Probing as a whole is 
controlled by TAXi^ControLprobe 676 (see also Fig. 4g); if this bit is Zero, probing is disabled. 
To ensure that control is only transferred to TAXi code whose underlying X86 code is 
unmodified since the translation was generated, probing is only allowed on protected pages of 

10 X86 instruction text, as controlled by XP bit 184, 186 for the page (see also Fig. Id, and sections 
I.F, supra, and section VIII, infra); if XP bit 184, 186 is Zero, no probes are taken on the page. 
Probing is controlled for X86 contexts by TAXi_Control.Global_TAXi_Enables. sizes 470 and 
.modes 472 bits, which are set by TAXi system control software. Probing is only enabled for 
current X86 modes whose TAXi_Control.Global_TAXi_Enables 470, 472 are set to One. 

15 Probing and profiling are mutually exclusive (see section VI.G, infrd)\ thus probing is disabled 
when TAXi_State.Profile__Active (482 of Figs, 4h, states 530 and 542 of Fig. 5a, see section V.E 
and V.F, supra) is One. If the output 678 of AND gate 674 is One, then the processor continues 
to the next step of determining whether to probe PIPM 602, as discussed further infra. 

TAXi_Control .probe 676 was Zeroed by software when the X86 processor entered a 

20 mode that TAXi is not prepared to handle, e.g. , X86 debugging, single-step or floating-point 
error conditions. When operating in "page property processing disabled" mode (with 
PROC_CTRL.PP_Enable deasserted, see section LA, supra), TAXi_Control. probe 676 is 
deasserted. 

The output 678 of AND gate 674 latches the single bit of the probe event class into 
25 Decoded_Probe Event latch 680. 

An intermediate step 690 to be performed in hardware, discussed in detail in section 
VI.E, infra, may optionally be performed here. 

If all of the hardware checks described supra pass, then the processor takes a probe 
exception before completing execution of the instruction at the target of the control transfer. The 
30 probe exception transfers control to software that continues to fiirther test whether control should 
be transferred to the TAXi code. 
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As part of generating a probe exception, converter 136 writes (step 682) a 
Context_At_Point profile entry (430 of Fig. 4c) to the register indicated by 
TAXi_Control.Packet_Reg_First (476 of Fig. 4g) defined for profile collection, (as will be 
explained further in section VLG, infra, profiling and probing are mutually exclusive, and the 
5 X86 does not use the profile collection registers, so the three uses cannot conflict.) The event 
code (436 of Fig. 4c) of the profile entry 430 is set to the least significant 4 bits of the current 
event code (592 of Fig. 5b). 

On entry to the probe exception handler the following information is available from the 
converter: 

10 •A Context_At_Point profile entry 430, containing the X86 physical IP (page frame 

number and page offset) in low half 438, 439 

• X86 execution context, from high half 432, 433, 435 of Context_At_Point 430 
probe event code in the event code field 436 of Context_At_Point 430 

• X86 virtual IP (offset into the CS segment ) from EPC.EIP 

15 

The exception handler consults PIPM 602. PIPM 602 is a table that maps X86 
instruction addresses (their physical addresses, after address translation) to addresses of TAXi 
code segments. The table entry in the PIPM is indexed by X86 physical address, typically using 
a conventional hashing technique or other table lookup technique. The probe exception handler 
20 looks up the physical address of the target instruction in the Physical IP to TAXi code entry point 
Map (PIPM) 602. 

If no PIPM entry 640 with a matching X86 address is found, then the probe has failed, 
with consequences discussed infra. 

Once a table entry with an address match is located, the translation must be further 
25 qualified by the current X86 mode. Recall that the full execution semantics of an X86 

instruction is not fully specified by the bits of the instruction itself; execution semantics depend 
on whether the processor is in V86 mode, whether addressing is physical or virtual, the floating- 
point stack pointer, and the fiiU/empty state of floating-point registers, and operand sizes are 
encoded in segment descriptors, the EFLAGS register, the floating-point status word, the 
30 floating-point tag word, etc. The translation into Tapestry native code embeds assumptions 
about these state bits. These state bits were initially captured in bits <59:51> of a 
Context_At_Point profile entry 430 (see section V.C, supra) and then hot spot detector 122 and 
binary translator 124 generated the translation based on the profiled values of the mode bits. The 
corresponding PIPM entry 640 for the translation records the mode bit assumptions under which 
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the TAXi code segment was created. Thus, once PIPM entry 640 is found, the current X86 mode 
is compared against the X86 mode stored in PIPM entry 640. 

The exception handler makes three general classes of checks of the mode information in 
PIPM 602. 

5 First, the current execution mode and the value of the CS.D (code and operand size) and 

SS.D (stack segment size) bits assumed by TAXi translator 124 must be compatible. This is 
determined by comparing the decoded "sizes" information 432 from the Context_At_Point 
argument with the mask of acceptable contexts provided in PIPM entry 640, 646. 

If the current floating-point state does not match the floating-point state 648 in PIPM 

10 entry 640, then the probe fails. In some cases, disagreements can be resolved: the floating-point 
unit can be unloaded and reloaded to conform to the floating-point state in PIPM entry 640, for 
instance, to get the floating-point registers into the canonical locations specified by the current 
X86 floating-point map. If the height of the floating-point register stack mismatches the stack 
height in PIPM entry 640, or the pseudo floating-point tag words mismatch, or the floating-point 

1 5 control words (precision and rounding modes) mismatch, then the probe fails. If the only 
mismatch is the mapping of the floating-point tag map (the map from the X86 stack-based 
register model to the register address Tapestry model), then software can reconfigixre the 
floating-point state to allow the probe to succeed. 

Execution control is tendered to the TAXi code. If the modes mismatch, the probe fails. 

20 Second, the current virtual IP value must be such that (a conservative approximation of) 

the transitive closure of the TAXi code points reachable by invoking this TAXi fragment would 
not trigger a CS limit exception. This is determined from the virtual IP at the time of the 
exception and normalized CS limit, and comparing them to values stored in PIPM entry 640. 

Third, because the TLB copy of the XP bit 186 may be slightly stale relative to the PFAT 

25 copy 184, the master copy of the XP bh 184 in PFAT 172 is checked to ensiire that all cached 
information (the profile and TAXi code) associated with the X86 page is still valid. 

Fourth, DMU 700 (see section VII, infra) may be queried to ensure that the X86 page has 
not been invalidated by a DMA vrate. 

If the current X86 mode satisfies the mode checks, then the probe has succeeded. PIPM 

30 entry 640 contains the address of the TAXi code corresponding to the address of X86 code at 
which the probe exception occurred. If the modes mismatch, the probe fails. 
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When a probe exception succeeds, the handler modifies the EPC by setting 
EPC.TAXi_Active, Zeroing EPC.ISA (native Tapestry mode), setting EPC.EIP to the address of 
the TAXi code, and setting EPC.ESEG to the special TAXi code segment. The RFE instruction 
completes the transfer of execution to the TAXi code by loading the EPC into the actual 

5 processor PSW. A successfiil probe leaves the Probe Mask 620 unaltered. Thus, classes of 
probeable events remain enabled as long as each probe in the class is successful. 

By resetting the EPC.EIP to point to TAXi translated code, the RFE instruction at the end 
of the probe exception handler effects a transition to the TAXi code. Because the TAXi code 
was transliterated from X86 code, it follows the X86 convention, and thus the argument copying 

10 that would have been performed by the transition exception handler (see sections II, III, and IV, 
supra) is not required. Further, because both the probe exception handler and the TAXi code are 
in Tapestry ISA, no probe exception occurs on this final transition. 

When a probe exception is triggered, and the software probe fails to find a translation, 
several steps are taken. The bit in Probe_Mask 620 that corresponds to the event that triggered 

1 5 the probe is cleared to Zero, to disable probes on this class of event until the next expiry of 
Probe_Timer 630. This is accomplished by the Probe Failed RFE signal and the remembered 
Decoded_Probe_Event latch 680, The interrupt service routine retums using an RFE with one of 
two special "probe failed" event codes of Fig. 4b. Event code 0.001 1 forces a reload of 
TAXi_Timers.Probe_Timer 630 with the Probe_Timer_Reload_Constant 632, Event code 

20 0.0010 has no side-effect on Probe_Timer 630. It is anticipated that when a probe on a 

backwards branch fails, Probe Timer 630 should be reset, by returning from the probe exception 
with an RFE of event code 0.001 1 , in order to allow the loop to execute for the full timer value, 
with no further probe exceptions. On the other hand, it is anticipated that when a probe on a 
"near CALL" fails, testing other near calls from the same page should be allowed as soon as 

25 Probe_Timer 630 expires, and thus this probe exception will return with an event code of 0.0010. 
The RFE retums to the point of the probe exception, and execution resumes in converter 136. 

If an RFE instruction that modifies Probe Mask 620 is executed at the same time that the 
probe timer expiry attempts to reset Probe_Mask 620, then the RFE action has higher priority 
and the reset request is discarded. 

30 
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E. Additional features of probing 

In the intermediate step 690 mentioned briefly supra, a bit vector of bits indicates 
whether a translation exists for code ranges somewhat finer than the page level encoded in the 
PFAT probe bits. After a probeable event occurs, and the class of that event is screened against 

5 the PFAT probe bits and the probe mask, the hardware tests the bit vector (in an operation 
somewhat reminiscent of a page translation table walk) before actually raising the probe 
exception and transferring control to the software interrupt handler. 

Only the slices of the bit vector that correspond to pages with non-zero PFAT probe bits 
are actually instantiated by software, again similar to the way only the relevant portions of a full 

10 page table tree are instantiated by a virtual memory system. The bit vector itself is hidden from 
the X86 address space, in an address space reserved for the probe bit vector and other structures 
for managing the X86 virtual machine. The bit vector may be cached in the d-cache - because of 
the filtering provided by the earlier steps, the number of unsuccessful queries of the probe bit 
vector will be relatively small. 

1 5 The density of the bit vector can be tailored to the operation of the system. In some 

embodiments, there may be a bit for every byte in the physical memory system. In other 
embodiments, the effectiveness of the bit vector would most likely be only marginally reduced 
by having one bit for a small power of two bits, for instance, one bit for every 2, 4, 8, 16, or 32 
bytes of physical memory. The block size guarded by each bit of the bit vector may be software 

20 configurable. 

Thus, where the probe properties 624 in PFAT 172 give a fine-grained filter by event 
code (the five probeable event classes), but are spatially coarse (on a page basis), the bit vector 
gives a coarse map on event code (all events grouped in a single bit), but is finely grained (a few 
bytes) by space. 

25 A One bit in the bit vector is not a guarantee that translated code exists and should be 

activated. As with the PFAT probe bits, the bit vector is somewhat over-optimistically heuristic, 
and may on occasion lag the actual population of translated code segments. Even after testing 
the bit vector, the mode predicates in PIPM 602 are still to be verified. 

The quasi-microcoded hardware used for table walking is readily modified to issue the 
30 loads to memory to fetch the appropriate slices of the bit vector. 

The logic of PLA 650 is programmable, at least during initial manufacture. 
Reprogramming would alter the contents of columns 414, 416, 418, 610, 612 of table at Fig. 4b. 
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Though the five-bit event codes generated by converter 136 are relatively fixed, the 
interpretation given to those bits, and whether to profile or probe on those events, is 
reconfigurable within PL A 650. In alternative embodiments, PL A 650 may be made 
programmable at run time, to control operation of profiling and probing by altering the contents 
5 of the columns of Fig, 4b. The five bits of input (event code latch 486, 487) to PL A 650 give 
2^=32 possible inputs. There are nine bits of output (probeable event signals 660, 661, 662, 663, 
664, 665, profitable event 416, initiate packet 418, and probeable event 610), Thus, PLA 650 
could be replaced by a 32%9 RAM, and the outputs of PLA 650 would then be completely 
software configurable. With that programmability, both profiling (section V, above) and probing 

10 (this section VI) become completely configurable. In a programmable embodiment, the 

overhead of profiling and probing can be controlled, and strategies can be adapted to experience. 

Most of the attributes required for a probe are associated with pages (stored in the PFAT 
and TLB), or with individual translated code segments (stored in PIPM 602), a structure queried 
by converter 136 as simple X86 instructions are executed in hardware. For complex instructions 

15 that are executed in the emulator (316 of Fig, 3a) the decision to probe or not to probe is made in 
software. A side table annotates the X86 IVT (interrupt vector table) with probe attributes, much 
as the PFAT is a side annotation table to the address translation page tables. After emulating an 
X86 instruction, emulator 316 queries the IVT side table, and analyzes these bits in conjunction 
with the machine state determined during the course of the emulation. On the basis of this query, 

20 emulator 316 decides whether to return to converter 136 using an RFE with an event code that 
induces a probe, or an RFE with an event code that does not. Event codes 0.1 100 and 0.1110 
induce a probe (see column 610 of Fig. 4b), and event codes 0.1 101 and 0.1 1 1 1 do not. 

F. Completing execution of TAXi code and returning to the X86 code 

25 Once a probe exception activates some translated TAXi code within an X86 process, 

there are only three ways to leave that TAXi code, either a normal exit at the bottom of the 
translated segment, a transfer of control out of the code segment, or an asynchronous exit via an 
exception. 

The fall-out-the-bottom case is handled by epilog code generated by the TAXi translator 
30 124. The TAXi code will home all X86 machine state and return control to the converter by 
issuing a trap instruction. A trap instruction transfers control to an exception handler for a 
TAXi_EXIT exception. The trap handler for exiting TAXi code sets the ISA to X86 and returns 
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control to the point in the X86 code following the translated hot spot. In the alternative 
embodiment of section IV, epilog code returns data to their X86 homes, and sets the IP to point 
to the point following the end of the portion of the X86 code that was translated. 

The transfer of control case may be handled by the state saving mechanism described in 
5 section III, supra, or may be handled by code essentially similar to the epilog code discussed 
supra. In any case, the Tapestry system takes explicit actions to reconstruct the X86 machine 
state. 

Asynchronous exits are handled by exception handlers, using the safety net mechanism 
introduced in section I.D, supra, and discussed in more detail in section VIII, infra. When an 

10 exception occurs in TAXi code and the exception handler determines that it must materialize the 
exception in the X86 virtual machine, it jumps to a common entry in emulator 316 that is 
responsible for setting the X86 state - establishing the interrupt stack frame, accessing the IDT 
and performing the control transfer. When this function is invoked, it must first determine if 
TAXi code was being executed by examining PSW.TAXi Active 198, and if so, jump to a TAXi 

1 5 function that reconstructs the X86 machine state and then re-executes the X86 instruction in the 
converter to provoke the same exception again. Re-executing the X86 instruction is required to 
establish the correct X86 exception state. Anytime the converter is started to re-execute an X86 
instruction, the exception handler uses the RFE with probe failed, reload probe timer event code 
to prevent a recursive probe exception from occurring. 

20 The only exceptions that may not be materialized in the X86 world are those that can be 

completely executed by native Tapestry code, e.g. TLB miss that is satisfied without a page fault, 
FP incomplete with no unmasked X86 floating-point exceptions, etc. 

G. The interaction of probing and profiling 

25 Probing and profiling are mutually exclusive. Probing only occurs when there is a 

probeable event (column 610 of Fig. 4b) while TAXi_State.Profile_Active (482 of Fig, 4h and 
5a) is Zero. These constraints are enforced by AND gate 674 of Fig. 6b. On the other hand, 
profiling is only enabled while TAXi_State.Profile_Active 482 is One. Thus, when the 
processor takes a probe exception, the mutual exclusion guarantees that the resources used by 
30 profiling are quiescent. In particular, the general registers in which profile packets accumulate 
are guaranteed to be available for use to service the exception. 
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Every probeable event 610 is also an "initiate packet'' event 418. This reflects a practical 
design consideration; the class of probeable events 610 are the most important events in the flov^ 
of a program, and "initiate packet" events 418 are a somev^hat broader set of important events. 
If a probeable event 610 occurs in a class for which probing is enabled, and 

5 TAXi_State.Profile_Active (482 of Fig. 4h and 5a) is Zero, then the event is also an "initiate 
packet" event 418. If, further, TAXi_State.Profile__Request 484 is One, then profiler 400 would 
naturally trigger a transition of TAXi_State.Profile_Active (482 of Fig. 4h and 5a) and 
TAXi_State.Profile_Request 484, transition 522 of Fig. 5a. This would violate mutual 
exclusion. However, the probe exception is higher priority than any activity of profiler 400. 

10 Thus, on a successful probe, control is transferred to the TAXi code, and any profiler action is 
suppressed. If the probe fails, the probe class is disabled, and profiler 400 is allowed to take its 
normal course, as described in Figs. 5a and 5b and section V.F, supra. 

The content of a profile packet, and in particular, a Context_At_Point profile entry (430 
of Fig. 4c), is tailored to efficiently represent the information required by hot spot detector 122 

15 (to precisely identify the ranges of addresses at which fi-equently-executed instructions are 

stored), and efficiently tailored for the binary translator 124 (to capture the X86 semantic mode 
information that is not represented in the code text itself), and efficiently tailored for prober 600 
(the information required to qualify a probe, to ensure that the semantic mode assumptions under 
which the binary was translated are met by the current X86 semantic mode, before transferring 

20 control to the TAXi code). Though the representation is not optimal for any one of the three, it is 
very good for all three. In other embodiments, the representation may be tailored to promote 
efficiency of one of the three over the others, or solely for the benefit of one. 

The fact that probeable events 610 are a subset of "initiate packet" events 418 has a 
further desirable side effect: the hardware to capture information for the first profile entry 430 in 

25 a packet can be reused to capture the information needed by the probe exception handler. When 
a decision is made in hardware to deliver a probe exception, the exception handler is provided 
with information about the physical address to which control was being passed and the context of 
the machine. The information for a probe exception is gathered in register 594 of Fig. 5b, in a 
form that mirrors the form captured in a Context_At_Point profile entry 430. In the process of 

30 either generating a probe exception in hardware, or servicing it in software, the content of 

register 594 is captured into a general register. This capture (when supplemented with the CS 
limit (code segment length), as stored in an X86 segment descriptor register) supplies the 
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information needed by the probe exception handler: the physical address of the next instruction, 
used to index PIPM 602 and find a possible candidate entry, and the X86 mode information 
needed to qualify that entry. The address captured in the Context_At_Point 430 has the physical 
page number, ready for use to index into PIPM 602. Since all probeable events are "initiate 

5 packet" events, the mode information is readily available in the Context_At_Point profile entry 
430 that initiates the packet identifying the hot spot. The various snapshots can be compared to 
each other for compatibility by AND'ing the appropriate bits together. 

Unlike profile collection, which operates by periodic sampling, probing is always enabled 
when the converter is active, the TAXi_Control. probe flag is One, and the probe mask has at 

10 least one surviving One bit. 

H. Alternative uses of adaptive opportunistic statistical techniques 

The adaptive opportunistic execution policy described in section VI.A through VLE can 

be used in a number of settings in a CPU design. 

1 5 In one example embodiment, a CPU might have a fast path and a slow path through the 

floating-point unit, where the fast path omits full implementation of the IEEE-754 floating-point 
infinities, denormalized nimibers ("denorms") and NaNs, and the slow path provides a full 
hardware implementation. Because infinities, denorms and NaNs tend to arise infrequently, but 
once generated tend to propagate through more and more of the computation, it is advantageous 

20 to start with the optimistic assumption that no denorms or NaNs will arise, and to configure the 
CPU to use the fast path. Once an infinity, denorm or NaN is detected, then the CPU may revert 
to the slow path. A timer may be set to run, and when the timer expires, the CPU will resume 
attempting the fast path. 

In another example embodiment, a cache system might use an analogous adaptive 

25 opportunistic technique. For instance, a multi-processor cache might switch between a write- 
through policy when inter-processor bus snooping indicates that many data in the cache are 
shared, write-in when it is noted that shared data are being used intensively as a message board, 
and write-back when the bus snooping indicates that few data are shared. A cache line flush or 
invalidate is the "failure" that signals that execution must revert to a higher-cost policy, while a 

30 successful write in a lower-cost policy is a "success" that allows continued use of the lower-cost 
policy. The adaptation might be managed on the basis of address ranges, with a record of 
success and failure maintained for the distinct address ranges. The switch between mode can be 
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managed by a number of techniques. For instance, a counter might count the number of 
successive memory accesses that would have been more-efficiently handled if the cache were in 
another mode. When that counter reaches a threshold value, the cache would be switched into 
the other mode. Or, a timer might set the cache into a more-optimistic mode, and an access that 
violates the assumption of optimism would set the cache into a less-optimistic mode. 

The opportunistic policy might be used in branch prediction, cache prefetch or cache 
enabling. For instance, cache prefetching might be operative for as long as prefetching is 
successful. Or, a particular LOAD instruction in a loop may be identified as a candidate for 
cache prefetching, for as long as the prefetch continues successfully. When the prefetch fails, 
prefetching is disabled. 

A multiprocessor cache might cache certain data, on optimistic assumptions, and then 
mark the data non-cacheable when inter-processor cache trashing shows that caching of these 
data is unprofitable. 

Opportunistic policies might be useful in memory disambiguation in object-oriented 
memory systems. For instance, a compiler might generate two alternate codings for a source 
construct, one assuming that two objects are disjoint, one assuming overlap. The optimistic 
disjoint code would be used for as long as the optimistic assumption held, then control would 
revert to the pessimistic code. 

VII. Validating and invalidating translated instructions 

The TAXi system is analogous to a complex cache - the profile data and TAXi code are 

kept current with the pages of X86 instruction text, and must be invalidated when the X86 
instruction text is modified. There are two possible sources for modifications to the X86 
instruction text: memory writes by the CPU, and writes from DMA devices. Writes from the 
CPU are protected by the XP protected bit 184, 186, discussed at section I.F, supra, and validity 
checks in PIPM 602, as discussed in sections VLC and VI.D, supra. This section VII discusses 
protection of the cached information against modification of the X86 instruction text by DMA 
writes. 

Referring to Fig. 7a, DMU 700 (the DMA Monitoring Unit) monitors DMA writes to 
ASI Zero (address space zero, "well-behaved" non-I/0 space) in order to provide a condensed 
trace of modification of page frames. DMU 700 performs this monitoring without imposing 
excessive overhead. DMU 700 is implemented as an I/O device in the I/O gateway, instead of 
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directly on the main processor bus (the G-bus). This gives DMU 700 visibility to detect all non- 
processor updates of X86 code pages in physical memory (except for those initiated by the 
processor itself, which are masked by the behavior of a write-back cache). 

A. A simplified DMU model 

A simple DMU provides modified page frame (MPF) bit for each physical page frame in 
the system. An MPF bit of Zero indicates that no modification has occurred, and if a DMA 
transfer were to write into the corresponding page frame then a modification event would need to 
be reported against that page firame. An MPF bit of One indicates that DMA writes to the 
corresponding page frame should pass unreported. 

This simple DMU is initialized by Zeroing all MPF bits. Then, for every DMA write, the 
relevant MPF bit is checked. If that MPF bit was already One, no further processing occurs. If 
the MPF bit is still Zero, then it is set to One, and the identity of the modified page frame is 
reported, for instance by creating an entry in a FIFO. Once a page frame's MPF bit becomes 
One, and the modification is reported, no amount of additional DMA writing to that page frame 
will produce another modification report. 

This simple DMU provides tremendous condensation in the reporting of page 
modifications; in fact, it generates a provably minimal number of modification reports. The proof 
follows from the fact that DMU 700 itself never Zeros any MPF bits - it only sets them to One. 
The number of modification reports possible is bounded by the number of MPF bits, or 
equivalently, the number of page frames. Because most DMA writes are to the buffer pages for 
"data" I/O, and the important writes to be monitored are to pages of X86 instruction text, which 
are written less often, this behavior reduces overhead while preserving correct behavior. 

So long as a page frame's MPF bit remains Zero, tiie TAXi system is assured tiiat no 
DMA modification has occurred since that MPF bit was last cleared to Zero. Thus, whenever 
profiler 400 is about to profile an X86 page, generate a TAXi ti-anslation, execute a TAXi 
translation (the operations that cache information about the page or use cached information), that 
page's MPF bit is Zeroed, and any queues or FIFO's that might contain pending modification 
reports are flushed. Now profile or translation information fi-om the page may be encached. 
Whenever a modification of the page frame is reported, any encached information about the page 
is discarded. Once the cached information is purged, then the MPF bit for the page can be reset 
to Zero, and information about the page may again be cached. 
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B. Overview of a design that uses less memory 

While the simple design described in section VILA, supra, would execute correctly and 
would impose little interrupt overhead, it might consume too much memory. On a system with 

5 28 bits of physical address space and 4 KB page frames there are 65K page frames. This 
translates into 8 KB (or 256 256-bit cache Unes) worth of storage just to hold the MPF bits. 
Those bits could be stored in memory but then, since a DMA read of such a memory based 
structure in response to every DMA write cycle would be unacceptable, DMU 700 would have to 
include some kind of caching mechanism. 

10 The design described in this section is very similar to the simple model of section VILA. 

In the embodiment discussed infra, small, regular, naturally-aligned slices of the full MPF array 
are instantiated as needed, to monitor corresponding ranges of the physical address space. This 
design monitors only a subset of the entire physical address space at any given moment. When 
idle monitoring resources are reclaimed to monitor different physical addresses, this design for 

1 5 DMU 700 makes the conservative assumption that no page frame within the range that is about 
to be monitored has had a modification reported against it. This conservative assimiption 
induces redundant reports of modification to page frames for which modifications had already 
been reported at some point in the past. 

20 C, Sector Monitoring Registers 

Referring to Fig. 7a, DMU 700 has several Sector Monitoring Registers (SMR) 707, 

typically four to eight. In the example embodiment discussed here, it is assumed that there are 
four SMR's 707 in the SMR file. Each SMR 707 monitors a sector, a naturally-aligned region of 
a power of 2 number of page frames. In the embodiment of Fig. 7a, a sector is a naturally- 

25 aligned 128 KB range of the G-bus physical memory address space, or equivalently, a naturally- 
aligned group of thirty-two 4 KB page frames. Each SMR 707 consists of a content addressable 
sector CAM (content-addressable memory, analogous to a TLB address tag) 708, an array of 
MPF (Modified Page Frame) bits 710, an Active bit 711, and a small amount of logic. Sector 
CAM address tag 708 is eleven bits for a 28-bit physical address space (28, less 12 bits of byte 

30 addresses within a page, less 5 bits for the 32 pages per sector - see Fig, 7a). MPF array 710 has 
32 bits, one bit for each page frame in the sector. Each MPF array is essentially a 32-bit slice of 
the large MPF bit array described in section VILA. (In order to maximize the opportunity to use 
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large DMA transfers, modem operating systems tend to keep sequential virtual pages in 
sequential clusters in physical memory, so clustering of pages in an MPF array 710 offers much 
of the advantage of distinct MPF bits at lower address-tag matching overhead.) SMR. Active bit 
711 is set to One if there v^as at least one Zero-to-One transition of an MPF bit 710 since the last 

5 time the SMR 707 was read. Thus, an SMR 707 is Active 711 when it contains at least one MPF 
bit 710 that has transitioned from Zero to One since the last time the SMR 707 was read out via 
DMU_Status register 720 (see section VILG, infra.) DMU 700 will never reassign an active 
SMR 707 to monitor a different sector. 

A DMU interrupt is asserted when one or more page frames have been modified, that is, 

10 when an MPF bit transitions from a Zero to a One. The handler for the DMU interrupt identifies 
the modified page frame(s). If the modified page is X86 text, then any translated TAXi code, 
and any profile information describing the page, are purged, and the corresponding PIPM entry 
640 is released. 

Referring to Fig. 7a, the physical address space is divided into 4K pages in the 
15 conventional maimer. The pages are grouped into contiguous blocks called sectors. In the 

embodiment of Fig. 7a, thirty-two contiguous, naturally-aligned pages form one sector. In this 
embodiment, which allows for a maximum of 256 MB of physical memory, bits <27:17> 702 
designate the sector. In other embodiments, more physical memory can be accommodated by 
extending the number of bits 702 to designate a sector. Bits <16:12> 704 designate the page 
20 number within a sector 702. Bits <1 1 :00> designate a byte within a page. 

D. Interface and Status Register 

Fig. 7b illustrates the DMU interface. Writing to DMU Command register 790 provides 
the sector address 702 and page address 704 (which in turn, is the bit address for the page's MPF 

25 bit within the SMR 707) and a DMU 700 command from the G-bus data. The low six bits of a 
datum are written to DMU_Command register 790 designates the command. The six bits of the 
command portion are designated D, E, R, A, M and X 791a-796a. (The meaning of these bits is 
discussed in detail in section VII.H, infra.) When a DMA device issues a write to memory, the 
command value is D, E, R equal to Zero and A, M, X equal to One. From the D, E, A, M, X and 

30 R signals, several predicates are derived. Enable signal 714 means that the DMU is currently 
enabled. Allocate signal 715 is asserted on a bus transaction in which memory is written from a 
DMA device, and thus an SMR register must match, or be newly allocated to track the write. 
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MPF modify signal 716 is asserted when the setting of the command bits specifies that the 
contents of an MPF bit 710 is to be written. MPF data signal 717 carries a datum to be written to 
an MPF bit 710 when MPF modify 716 is asserted. Reset signal 718 is asserted when the R reset 
command 794a is asserted on the bus. Read signal 719 is asserted as a distinct line of the G-bus 
5 Fig. 7b also shows the Enable and Overrun flip-flops and the interrupt generation logic. The 
meanings of the six command bits 791a-796a are discussed in more detail infra, in connection 
with Figs. 7i and 7j. 

When DMU 700 is enabled 714, DMU 700 requests an interrupt anytime there is at least 
one SMR 707 whose SMR.Active bit 711 is One or whenever the DMU Overrun flag 728 is set. 

10 The value of the active 711 SMR 707 is exposed in DMU_Status register 720. 

Referring to Fig. 7c, DMU Status register 720 is 64 bits wide. The sector bits are located 
at their natural position, bits <30:17>, within a physical address, allowing for implementations 
with up to 2 GB of physical memory. The DMU_Status.Active bit 723 (bit <31>) is One when 
an active 711 SMR 707 is selected and Zero when all SMR's 707 are inactive. The least 

15 significant Modified Page Frame bit (SMR<32>) 724 corresponds to the page frame at the 

lowest address within a sector. Successive MPF bits 710 correspond to successively higher page 
frames. When DMU_Status.Active bit 723 is One, then the value of SMR# field 725 
(SMR<02:00>) identifies the SMR 707 being returned. When DMU_Status.Active bit 723 is 
Zero, the Modified Page Frame bits 710, Sector bits 722 and SMR# 725 are all Zero. 

20 The Enable bit 727 and Overrun bit 728 are not actually part of any specific SMR 707. 

Rather they summarize the overall state of DMU 700 and all SMR's 707. Monitoring of DMA 
activity occurs only when DMU Enable 714 is set (DMU_Status. Enable 727 reflects the value of 
DMU Enable 714, which in turn is set by writing to DMU_Command.Enable 795, see Figs. 7i 
and 7j). Overrun bit 728 is provided at the time that an SMR 707 is read out, to allow 

25 recognition of cases when DMU 700 has shut down in response to a catastrophic ovemm 
condition. The position of Overrun bit 728 as bit <15> (the sign bit of a 16-bit segment of 
DMU_Status register 720) simplifies testing it. 

DMU Status register 720 is described further in section VII.G in connection with Fig. 

7h. 

30 
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E. Operation 

Referring to Fig. 7d, the following steps occur on each DMA write transaction. In step 
730, DMU Enable 714, 727 is tested. If the DMU is disabled, no further processing occurs. In 
step 731, the target physical address of the DMA bus transaction is captured into 

5 DMU_Command register 790. Bits <27: 1 7> 702 of the target address are captured as the sector 
number, and bits <17:12> 704 are captured as the page number index into an SMR of 32 MPF 
bits 710, as shown in Fig. 7a. In step 740, SMR sector CAM address tags 708 are searched 
associatively using the sector number. (This search will be elaborated further in the discussion 
of Fig. 7e in section VII.F.) If the search succeeds (arrow 732), control skips forward to step 

10 737. If there is no match with any sector CAM address tag 708 (arrow 733), in step 750, an 

inactive SMR 707 (one whose SMR. Active bit 711 is Zero) is allocated. (Allocation is discussed 
further in connection with Fig. 7f). If no inactive SMR 707 is available, then a catastrophic 
overflow has occurred, and in step 734, DMU Overrun 728 is set. On an overrun 728, TAXi 
processing is aborted, and all translated code segments are purged (it is known that the DMA 

1 5 write that caused the overrun 728 may have overwritten a page of X86 code that had 

corresponding TAXi code, but the identity of that page cannot be identified, so all pages of TAXi 
code are considered suspect). Once the TAXi "cache" is purged, TAXi operation can resume. If 
an inactive SMR 707 can be located (arrow 735), then in step 736 within the allocated SMR 707, 
all MPF bits 710 are Zeroed. Sector CAM address tag 708 of the allocated SMR 707 is loaded 

20 with the search key, sector number 702. With SMR 707 thus allocated and set, it now satisfies 
the associative search criteria, so control flows to step 737 as though the search of step 740 had 
succeeded. 

In step 737, within matching SMR 707, the MPF bit 710 corresponding to the modified 
page frame is tested. If the MPF bit 710 is already set to One (arrow 738), then no further 
25 processing is necessary. Otherwise (arrow 739), in step 760, 778, the appropriate MPF bit 710 
and the SMR. Active bit 711 are set to One (Active bit 711 may already be set). 

F. Circuitry 

Referring to Fig. 7e, sector match hardware 740 performs the associative search of the 
30 sector CAM address tags 708 to determine whether the sector 702 of the current DMA write 
transaction already has an SMR 707 associated. Sector compare circuit 741 simultaneously 
compares the sector address 702 from DMU_Command register 790 with each of the four CAM 
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address tag values 708 of the four SMR's 707 in the SMR file. Sector compare circuit 741 puts 
the result of this comparison on four bit bus 742: each line of bus 742 is set to One if the 
corresponding SMR address tag 708 matches the bus sector address 702. If any one of the four 
lines of bus 742 is One, then there was a match; OR gate 743 OR's together the four lines to 
5 determine whether a match occurred. Since the sector value in an inactive SMR 707 is 
undefined, more than one SMR 707 could match the incoming sector address 702. Unary 
priority function 745 resolves this ambiguity by deterministically selecting at most one of the 
four asserted lines firom bus 742. Thus, the "matched SMR" 4-bit bus 746 will always have at 
most one line set to One, 

10 Referring to Fig. 7f, SMR allocation hardware 750 allocates one of the inactive SMR's 

707 out of the pool for writing into when none of the current SMRs' address tags 708 match 
sector address 702. Inactive SMR function 751 selects one of the inactive SMR's 707 (those 
whose SMR, Active bits 711 are Zero) if one is available. If the current bus transaction writes 
into a memory sector 702 that has no SMR 707 with a corresponding address tag 708 (indicated 

15 by matched 744 being Zero), and no SMR 707 is inactive 711 to accept the write (indicated by 
Allocate 715 being One), then the Overrun 728 condition has occurred. Otherwise, the SMR-to- 
write mask 753 (a four bit bus, with the one line asserted corresponding to the SMR register to 
be written) is generated from the SMR-to-read mask 787 (a four bit bus, with the one line 
asserted corresponding to the SMR register to be read), the matched SMR mask 746 (a four bit 

20 bus, with the one line asserted corresponding to the SMR register whose CAM sector address tag 
matches the bus address sector 702) and the inactive SMR mask 754 (the complement of the four 
SMR Active bits 711 of the four SMR registers 707). 

After sector match circuitry 740 or allocation circuitry 750 has selected an SMR 707, 
MPF update logic 760, 772, 778 updates the appropriate MPF bits 710 and SMR.Allocate bits 

25 711 in the selected SMR 707. (Part of MPF update logic 760, the portions 772, 778 that update 
the SMR address tags 708 and SMR, Active bits 711, are shown in Figs. 7e and 7f and omitted 
from Fig. 7g.) The MPF bits 710 to modify are selected by MUX 761, whose select is the SMR- 
to-write mask 753. If the sector address 702 matched 744 none of the address tags 708 of any 
SMR 707, then this is a newly-allocated, empty SMR 707; AND gate 762 generates all Zeros so 

30 that all MPF bits 710 of the new SMR 707 will be Zeroed. MPF bit update function 763 

generates a new 32-bit value 764 for the MPF portion 710 of the selected SMR 707. The inputs 
to MPF bit update function 763 are the 5-bit page address 704 within the sector 702 (these five 
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bits select one of the 32=2^ bits of MPF), the old contents of the MPF 710, and the MPF modify 
signal 716. The outputs 764, 766 of MPF bit update function 763 are chosen according to table 
765. If the old MPF bit 710 value was Zero and the new bit 710 value is One, then a Zero-to- 
One MPF transition 766 signal is asserted. The 32 bits of new MPF value 764 are OR'ed 

5 together to generate MPF-all-Zeros signal 767. Write logic 768 determines which MPF bit 710 
to update, using as inputs the Reset 718, Allocate 715, matched 744, MPF modify 716, and 
SMR-to-write 753 signals. The outputs 770, 771 of write logic 768 are chosen according to table 
769. If column 770 is a One, then the MPF bits 710 of the SMR 707 selected by SMR-to-write 
mask 753 are written with 32-bit value 764. If column 771 is a One, then the other SMR's 707 

10 are written as well. Thus, the last line of table 769 indicates that a Reset 718 writes the all-Zeros 
value generated by AND gate 762 to all MPF registers 710. 

Referring again to Fig. 7f, write logic 772 determines a new SMR. Active bit 711 value to 
write according to table 773. The inputs to write logic 772 are Read 719, MPF all Zero's signal 
767 and Zero-to-One MPF transition signal 766. Colunm 774 tells whether to write the 

15 SMR. Active bit 711 of the SMR 707 selected be SMR-to-write 753 when the data inputs to write 
logic 772 match columns 719, 767, 766. If column 774 is One, then column 775 tells the data 
value to write into that SMR.Active bit 711. Similarly, column 776 tells whether or not to write 
the SMR. Active bits 711 of the unselected SMR registers, and column 777 tells the datum value 
to write. 

20 Referring again to Fig. 7e, the sector tag 708 of a newly-allocated 750 SMR 707 is 

written as determined by write logic 778 (write logic 778 is intertwined with write logic 768, 
772, and is presented here simply for expository reasons). Write logic 778 accepts as input 
Allocate signal 715 and matched signal 744, and computes its outputs according to table 779. As 
indicated by the center row of the table, when an empty SMR is allocated by allocate logic 750 

25 (the new allocation is indicated by Allocate 715 being One and the emptiness is indicated by 
matched 744 being Zero), then the sector address tag 708 of SMR indicated by SMR-to-write 
mask 753 is written. Else, as indicated by the top and bottom rows of table 779, no SMR 707 is 
written. 

Figs. 7d-7g are merely representative of one embodiment. Knovm techniques for 
30 associative cache or TLB address tag matching, cache line placement policies, and inter- 
processor modified and dirty bits are generally applicable to managing SMR's 707. (One 
difference should be noted. In a software-managed TLB, on a TLB miss, the PTE in memory is 
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updated, and then the PTE is copied into the TLB. Thus, there is always a reUable backing copy 
of the TLB. In the DMU design presented here, there is no backing memory for the SMR 
registers 707.) 

In an ahemative embodiment, in Fig. 7d, an additional step is performed in parallel with 
5 step 740: TLB 116 is consulted to determine the ISA bit 182 and XP bit 184, 186 for the page 
being written. Unless the ISA bit 182 and XP bit 184, 186 are both One (indicating a page of 
protected X86 code), the entire rest of the DMU can be bypassed. The DMU exists only to track 
the validity of the TAXi code "cache" over the original X86 code, and if no such TAXi code can 
exist, then the remaining functions can be omitted. 
10 Whenever an MPF bit undergoes a Zero-to-One transition, that is, when one or more page 

frames have been modified, a DMU interrupt is raised. The handler for the DMU interrupt 
identifies the modified page frame(s) by retrieving the state of all the active 711 SMR's 707. 
The search for an active SMR 707 is performed in hardware, as described next. 

1 5 G. DMU_Status register 

Referring to Fig. 7h in conjunction with Fig. 7c, DMU_Status register 720 is a 64-bit 

register on the G-bus. It is the only source of DMU information used in normal TAXi operation. 
If DMU Enable 714 (reflected in DMU_Status.Enable 727, bit <14> of DMU_Status register 
720) is Zero, then all reads of DMU_Status register 720 will return a result that is entirely Zero. 

20 Such a read does not re-enable DMU 700; DMU re-enablement is only accomplished by 

reinitialization. If DMU Enable 714 is One and no SMR's 707 are active 711, then all reads of 
DMU Status 720 will return a result that is entirely Zero except for a One in 
DMU^Status.Enable bit 727. If DMU Enable 714 is One and there is at least one SMR 707 
whose SMR. Active bit 711 is One, then reading DMU_Status 720 will retum a snapshot of one 

25 of the active 711 SMR's 707. This snapshot will have at least one MPF bit 710 set, 
DMU_Status. Active bit 723 set (reflecting SMR. Active bit 711 of the SMR 707) and 
DMU_Status.Enable bit 727 set. Reading the DMU_Status register 720 has the side effect of 
Zeroing SMR. Active bit 711 of the SMR 707 currently reflected in the DMU_Status register 
720, leaving the SMR 707 ready for reallocation 750, but the address tag 708 and MPF bits 710 

30 are left intact. Thus, fixrther DMA writes into the same page will not induce a new Zero-to-One 
transition reducing the interrupt overhead induced by intensive I/O to I/O buffers. That SMR 
707 will become active 711 again only if it gets reallocated 750 or if a DMA v^ite occurs within 
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the sector 702 that it monitors to a page frame whose MPF bit 710 is Zero. Similarly, a DMU 
interrupt will only be raised for that page if the MPF bit for the page is explicitly cleared (using a 
command where the M command bit is One, and all other command bits are Zero, see the 
commands discussed in section VII .H). 

5 DMU_Status register 720 is driven by inputs from the file of SMR's 707. The SMR 

select function 782 chooses an SMR 707 whose SMR.Active bit 711 is One. The selection 783 
of the active SMR is used to select 784 the corresponding sector tag 708 and MPF bit 710 
portions of the selected SMR 707. When there is no active 711 SMR 707 (computed by OR gate 
785), or the DMU is disabled 714, then AND gates 786 ensure that all outputs are Zero. The 

10 selection 783 is gated by an AND gate to generate SMR-to-read signal 787, which is used in Fig. 
7f to select one SMR register to be read. 

Returning to the operation of the interrupt handler software, the act of reading DMU- 
_Status register 720 is taken by DMU 700 as an implicit acknowledgment of the notification and 
hence a sign that the SMR(s) 707 involved can be reassigned. The DMU interrupt handler 

1 5 checks ISA bit 180, 182 and XP bit 184, 186 for the page to see whether the page written by the 
DMA write is a protected X86 page (this can be done in hardware before raising the interrupt, or 
in software). If the page is a protected X86 page, then the interrupt handler consults PIPM 602 
to see whether any translated TAXi code exists corresponding to the modified page, and whether 
any profile information 430, 440 exists describing the modified page. If TAXi code is found, 

20 then it is released, and PIPM 602 is updated to reflect the release. If profile information is found, 
then it is released. 

The DMU interrupt has higher priority than the probe exception, so that a probe will not 
transfer control to a page that has recently been invalidated. 

25 H. DMU_Command register 

Referring to Figs. 7i, 7j and Table 5 in conjunction with Fig. 7b, software controls DMU 

700 through the DMU_Command register 790. Bits <05:00> 791-796 control initializing DMU 
700, response after an overrun, re-enabling reporting of modifications to a page frame for which 
a modification might already have been reported, and simulating DMA traffic. The fimctions of 
30 the bits 791 are summarized in the following Table 5. 
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Table 5 


command 
bit 


bit 
position 


Meaning 


D 


5 


Disable monitoring of DMA writes by Zeroing the DMU enable flag 


E 


4 


Enable monitoring of DMA writes by setting the DMU Enable flag to 
One 


R 


3 


Reset all SMR s: Zero all A and MPF bits and Zero the DMU overrun 
flag 


A 


2 


Allocate an inactive SMR on a failed search 


M 


1 


AUov^ MPF modifications 


X 


0 


New MPF bit value to record on successful search or allocation 



D command bit 796a, 796b, 796c Zeros DMU Enable 714, 727, thereby disabling any 
further changes to the SMR's 707 due to DMA traffic. If DMU Enable 714, 727 is already Zero, 
D bit 796 has no effect. 

5 E enable command bit 795a, 795b, 795c sets DMU Enable 714, 727 to One, thereby 

enabling monitoring of future DMA traffic and DMA interrupts. If DMU Enable 714, 727 is 

already set, E bit 795 has no effect. 

R command bit 794a, 794b, 794c resets DMU 700. It does this by Zeroing the 

SMR. Active bit 711 and all MPF bits 710 in every SMR 707 and also Zeroing DMU Overrun 
1 0 flag 728. The R command bit 794 has no effect on the values in the sector address CAM address 

tags 708. The R command 794 takes precedence over the A, M and X commands 793, 792, 791, 

and resets DMU 700 whether or not DMU 700 is enabled. 

The high order bits (bits <27:12>) 797 of DMU_Command register 790 identify a page 

frame. Whenever a write occurs to DMU__Command register 790, the page frame address 797 is 
1 5 presented to the SMR sector CAM address tags 708, The A, M and X command bits 793, 792, 

791 control what happens under various conditions: 

1 . If the sector match hardware (740 of Fig. 7e) fails to find a match 744, and A command 
bit 793 is Zero, then do nothing. If there is no match 744, and A command bit 793 is 
One, then normal allocation 750 is performed, as described in connection with Figs. 7d 

20 and 7f. (Recall that normal allocation 750 can lead to an overrun condition 728 and 

hence to a DMU interrupt). 

2. If either sector matching 740 or sector allocation 750 succeeds, then the M and X 
command bits 792, 791 define three possible actions according to Table 6: 
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Table 6 


M 


X 


Action 


0 




Inhibit modification of the MPF bit 


1 


0 


Zero the corresponding MPF bit 


1 


1 


set the corresponding MPF bit to One 



Writing a page frame address 702, 704, 797 to DMU_Command register 790 with the M 
command bit 792 set to One and the rest of the command bits 791, 793-796 to Zero searches 740 
the sector CAM address tags 708 for a match. If a match 744 is found, the corresponding MPF 

5 bit 710 is Zeroed (because M bit 792 is One and X bit 791 is Zero, matching the second line of 
Table 6). This is how TAXi enables monitoring of a page that is about to be turned from a page 
whose ISA bit 180, 182 is One and XP bit 184, 186 is Zero (unprotected X86 code) into a page 
whose XP bit 184, 186 is One (protected X86 code). If the MPF bit 710 that is cleared by such a 
command was the only MPF bit 710 set in the SMR 707, then the SMR 707 reverts to inactive 

10 711 and can be reallocated 750 to monitor a different sector. SMR. Active bit 711 is only 

affected by an MPF transition from Zero to One, or a transition of the last MPF bit from One to 
Zero. Otherwise, SMR. Active bit 711 is unaffected by changes to the MPF bits 710. 

It is software's responsibility never to enable DMU 700 until the sector CAM address 
tags 708 contain mutually distinct values. Once an overrun 728 occurs this condition is no longer 

1 5 assured. Hence the safest response to an overrun is reinitialization: 

DMU^Command = D+R // Disable DMU, reset SMR's 707 

for (i = 0, i < #SMRs, i++) { // InitiaUze all SMR's 707 

// Initialize each SMR 707 to a distinct address, by 

// allocating a new SMR (A + M command bits) with 
20 // sector "j" Q«l) and page zero (1 «1 2) within the sector 

DMU_Command = (i«17) + (1«12) + A + M 

} 

DMU_Command = E+R // Enable DMU, free all SMR's 

25 If not properly initialized the behavior of DMU 700 is undefined, guaranteed only not to harm 
the chip nor to introduce any security holes. 

In an alternative embodiment, DMU 700 is more closely integrated with TLB 116. In 
these embodiments, DMU 700 has access to ISA bit 182 and XP bit 186 (see section LF, supra), 
and only raises an interrupt when a protected X86 page is written, or if the written page has no 

30 entry in TLB 116. 
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VIII. Managing out-of-order effects 

Requiring all memory references (memory loads, memory stores, and instruction fetches) 

to be in-order and unoptimized limits the speed-up achievable by TAXi. Often the only barrier 
to optimization is knowing whether or not a load references well-behaved memory or some un- 
5 memory-like object. Recovering the original order of side effects, and preserving perfect X86 
behavior, in spite of reordering and optimization by the TAXi translator, is discussed in section 
VUI. 

A. Ensuring in-order handling of events reordered by optimized translation 

1 0 Binary translator 124 is allowed to use code optimization techniques that reorder memory 

read instructions, floating-point instructions, integer divides, and other instructions that may 
generate exceptions or other side effects, in spite of the fact that the TAXi execution model of 
perfect emulation of the X86 maintains the order of side-effects. ("Side-effects" are permanent 
state changes, such as memory writes, exceptions that the X86/Windows architecture exposes to 

1 5 the application program, etc. Thus, a memory write and a divide-by-zero are each side-effects 
whose order is preserved relative to other side effects.) For instance, all memory references 
(memory reads, memory writes, and instruction fetches) are assumed to be "well-behaved," free 
of both exceptions and hidden side-effects. All side-effects are kept ordered relative to each 
other. Correct execution is then ensured by catching any violations of these optimistic 

20 assumptions before any side-effect is irreversibly committed. 

When profile information (see section V) tells TAXi translator 124 that a memory read 
can have a side-effect, for instance a read to I/O space (see section VIII.B, infra), then the X86 
code is translated using more conservative assumptions, assumptions that disallow memory 
references from being optimized to eliminate redundant loads, or to be reordered. This 

25 conservative code is annotated as having been generated under conservative assumptions. When 
conservative code accesses I/O space, the memory reference is allowed to complete, because the 
annotation assures the run-time environment that the code was generated with no optimistic 
assumptions. References to well-behaved memory from conservative code complete normally, 
simply at the cost of the foregone optimization. 

30 Conversely, if no I/O space reference appears in the profile, then the TAXi code will be 

optimized under the optimistic assumption that all references are to well-behaved (that is, ASI 
Zero) memory - memory reads may be reordered or eliminated. The code is annotated to record 
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the optimistic assumptions. All references to well-behaved memory complete normally, 
regardless of the value of the annotation. When optimistic TAXi code is running, and a memory 
reference violates the optimistic assumption by referencing I/O space (ASI not Zero) from 
optimistic code, then the reference is aborted by a TAXi I/O exception. In TAXi code 

5 references to I/O space are allowed to complete only if the code is annotated as following 

conservative assumptions. When a TAXi I/O exception occurs, the exception handler will force 
execution to resume in the converter. 

When TAXi translator 124 generates native code, it may make the optimistic assumption 
that all memory references are to safe, well-behaved (ASI Zero) memory and can be optimized: 

10 e.g. , that loads can be moved ahead of stores, if it can be proved that the memory locations don't 
overlap with each other, that memory reads can be reordered with respect to each other and with 
respect to instructions that do have side-effects, and that redundant loads from the same location, 
with no intervening store, can be merged together (CSE'd - common sub-expression). TAXi 
translator 124 preserves all memory writes - memory writes are neither removed by optimization 

15 nor reordered relative to each other. However, references to I/O space, even mere reads, may 
have unknown side-effects (e.g., successive reads may retum distinct values, and/or trigger 
separate side effects in an I/O device - recall, for instance from section VILG, that a read of the 
DMU Status register 720 invokes a state change in DMU 700, so the next read of DMU_Status 
720 will give a different result). 

20 TAXi translator 124 relies on the safety net to protect references to non- well-behaved I/O 

space, that is, to intervene when the well-behaved translate-time optimistic assumption is 
violated at run time. The TAXi system records a static property of each memory reference, 
annotating whether that memory reference (specifically, a load) is somehow optimized. 

TAXi translator 124 conveys to the hardware whether a memory reference involves 

25 optimistic assumptions or not. Those references that involve no optimistic assumptions are 
always allowed to complete. Those that do involve the optimistic assumption that the target is 
well-behaved memory will have this assumption verified on every execution and are aborted if 
the assumption cannot be guaranteed correct. 

In one embodiment, one bit of each load or store instruction (or one bit of each memory 

30 operand descriptor in an instruction, if a single instruction makes multiple loads or stores) is 
reserved to annotate whether or not that particular load or store is optimized. 
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The following embodiment eliminates the need to dedicate one instruction opcode bit for 
this purpose. 

The optimistic/conservative annotation is recorded in the "TAXi Optimized Load" bit 
810 of a segment descriptor. 
5 Because every X86 load is based off a segment register (the reference to a segment 

register may be explicitly encoded in the load operation, or it may be implicit in the instruction 
definition), and every segment has a segment descriptor, the segment register is a useful place to 
annotate the optimized property, and to monitor memory references. As each X86 load operation 
is decoded into micro-ops to send down the Tapestry pipeline, the segment register is explicitly 

1 0 materialized into the micro-op. 

When TAXi code is running (that is, when PSW.TAXi Active 198 is asserted), and in 
TAXi translated code a load occurs in-order with respect to other memory references, then the 
effect will be identical to the original X86 instruction stream irrespective of the nature of 
memory referenced by that load. When memory references are not reordered, it is preferable that 

15 a TAXi Optimized Load 810 Zero segment be used, so that no exceptions will be raised. 

Referring to Fig. 8a, a Tapestry segment register 800 encodes a superset of the functions 
encoded in an X86 segment descriptor, and adds a few bits of additional functionality. Bit <61> 
of Tapestry segment register 800 is the "TAXi Optimized Load bit" 810. (The segment 
descriptor TAXi Optimized Load bit 810 is distinct from the TAXi_ControLtio bit 820.). When 

20 the segment descriptor TAXi Optimized Load bit 810 is One, all memory references off of this 
segment register are viewed as having been optimized under the optimistic assumptions. If a 
memory reference goes through a segment descriptor whose TAXi Optimized Load bit 810 is 
One, and the reference resolves to non-well-behaved memory (D-TLB.ASI, address space ID, 
not equal to Zero), and PSW.TAXi Active 198 is true, then a TAXi I/O exception is raised. The 

25 handler for the TAXi I/O exception rolls the execution context back to the last safety net 
checkpoint and restarts execution in converter 136, where the original unoptimized X86 
instructions will be executed to perform the memory references in their original form and order. 

The X86 has six architecturally-accessible segment descriptors; Tapestry models these 
six for the use of converter 136, and provides an additional ten segment descriptors 800 

30 accessible to native Tapestry code and TAXi code. The six X86-visible registers are managed by 
exception handlers in emulator 316 - when X86 code reads or writes one of the segment 
descriptors 800, the exception handler intervenes to perform both the X86-architecturally- 
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defined management and the management of the Tapestry extended functions. Converter 136 
and emulator 316 ignore the value of the segment descriptor TAXi Optimized Load bits 810; 
during execution of X86 code in converter 136, the value of bits 810 could be random. 
Nonetheless, converter 136 maintains bits 820 for the benefit of TAXi - in these six segment 
5 descriptors, the value of the segment descriptor TAXi Optimized Load bit 810 always matches 
Taxi_ControLtio (820 of Fig. 4g). 

The hardware format of a Tapestry segment register 800 differs from the architecturally- 
specified format of an X86 segment descriptor. Special X86-to-Tapestry hardware is provided to 
translate from one form to the other. When X86 code writes a segment descriptor value into a 

1 0 segment register, emulator 316 takes the segment descriptor value and writes it into a special 
X86-to-Tapestry conversion register. Hardware behind the special conversion register performs 
shifting and masking to convert from the X86 form to Tapestry form, copying the X86 segment 
descriptor bits into different bit positions, and gathering the Tapestry extended bits from 
elsewhere in the machine. In particular, the cloned segment descriptor's TAXi Optimized Load 

1 5 bit 810 is copied from TAXi Control.tio 820. Emulator 316 then reads the special conversion 
register, and that value is written into one of the Tapestry segment registers 800. 

At any particular software release, the value of TAXi_Control.tio 820 will always be set 
to the same value, and the TAXi translator 124 will rely on that value in translating X86 code. 
Referring to Figs. 8b and 8c, the segment descriptor TAXi Optimized Load bit 810 is 

20 managed by the TAXi translator 124, as follows. 

For the six segment registers visible to the X86, the default value of TAXi Optimized 
Load 810 is programmable at the discretion of the implementer. Recall that TAXi Optimized 
Load 810 is ignored by converter 136. Hence, each time the converter 136 loads a segment 
descriptor register (a complex operation that in reality is performed in emulator 316), TAXi 

25 Optimized Load can be set arbitrarily. The conversion of X86 format segment descriptor values 
into Tapestry internal segment descriptor format is performed by hardware. This hardware must 
provide some value to TAXi Optimized Load. Rather than hardwire the value, the Tapestry 
system makes the value of the TAXi Optimized Load bit 810 programmable via 
TAXi_Control.tio 820. 

30 At system boot TAXi_Control,tio 820 is initialized to reflect the form of loads most 

likely to be emitted by the current TAXi translator. If translator 124 is not especially mature and 
rarely or never optimizes loads, then TAXi_ControLtio 820 is initialized to Zero. This means 
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thai the segment descriptors mapped to the six architecturally visible X86 segment registers will 
alAvays have TAXi Optimized Load 810 Zero. Then code to clone the descriptor and set TAXi 
Optimized Load need only be generated in the prolog when a optimized load is actually 
generated. 

5 The defauh registers will all be in one state, chosen to be the more common case so that 

those registers can be the defaults for use by TAXi. When TAXi wants the other semantics, the 
descriptor cloning at the beginning of the TAXi segment will copy the descriptor used by 
converter 136, using a copy of TAXi_ControLtio 820 into the new segment descriptor's TAXi 
Optimized Load bit 810. The opposite sense for bit 810 will be explicitly set by software. For 

10 instance, if the default sense of the segment descriptor is TAXi Optimized Load of Zero (the 
more optimistic assumption that allows optimization), then all optimized memory references 
must go through a segment descriptor that has TAXi Optimized Load bit 810 set to One, a new 
descriptor cloned by the TAXi code. This cloned descriptor will give us all the other descriptor 
exceptions, the segment limits, all the other effects will be exactly the same, with the additional 

1 5 function of safety-net checking for loads. 

Referring to Fig. 8b, as the TAXi optimizer 124 translates the binary, it keeps track of 
which memory load operations are optimized, and which segment descriptors are referenced 
through loads that counter the default optimization assumption. Fig. 8b shows the actions taken 
in a near-to-last pass of translator 124, after all optimization has been completed, but before final 

20 emission of the new Tapestry binary. The upper half 840 of Fig. 8b covers the case of relatively 
early releases of TAXi optimizer 124, when optimization that reorders the side-effects is the 
exception rather than the rule. Lower half 850 reflects the later case, when optimization is more 
common, in which case the value of a segment's TAXi Optimized Load 810 would default to 
One, which in turn is controlled by setting TAXi Control.tio 820 to One. For memory 

25 references that are reordered, commoned, or otherwise optimized on the optimistic assumption 
that only well-behaved, side-effect-free memory will be addressed (steps 841, 851), TAXi 
translator 124 forces the memory references to go through a segment descriptor whose TAXi 
Optimized Load 810 value is One (steps 843, 852). If the assumption is violated, that is, if at run 
time the memory reference through a TAXi Optimized Load 810 One segment is found to access 

30 I/O space, then that memory reference will raise a TAXi I/O exception, and execution of the 

translated code will be aborted into the safety net of converter 136. If the TAXi translator 124 is 
willing to adopt conservative assumptions and not forgo opportunities to optimize this memory 
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reference (for instance, if the profile indicates that this load referenced I/O space, as discussed in 
section VIII.B) (steps 844, 853), then the memory reference can go through a segment descriptor 
whose TAXi Optimized Load 810 bit is Zero (step 845, 855), thus guaranteeing that this memory 
reference will complete and never generate a TAXi I/O exception, even if to non-well-behaved 
5 memory. 

In steps 842 and 854, TAXi translator records which segment descriptors are used in a 
non-default manner. The overhead of a cloning a descriptor, and setting a non-default value of 
TAXi Optimized Load 810, is only borne when required. 

Referring to Fig. 8c, at the beginning of each translated hot spot, TAXi translator 124 
10 inserts code that creates a cloned copy of any of the segment descriptors that were marked by 
steps 842, 854, as being used in a non-default way, into one of the ten extra segment descriptors 
(step 866). This cloned descriptor will be used for some of the memory references made by the 
translated code, those that match the assumption embedded in the current release's value of 
TAXi_ControLtio 820. The prolog code copies (step 866) the segment descriptor, and sets (step 
15 868) the TAXi Optimized Load bit 810 to the sense opposite to the value of TAXi_Control.tio 
820, for use by memory references that assume opposite to the assumption embedded in the 
current release's value of TAXi_Control.tio 820. 

TAXi Optimized Load bit 810 has the following run-time behavior. 
When converter 136 is running (that is, when PSW.TAXi Active bit 198 is Zero), the 
20 TAXi optimized load bit 810 has no effect. Therefore converter 136 can issue loads through a 
segment irrespective of the value of the TAXi Optimized Load bit 810. Whatever the value of 
TAXi Optimized Load bit 810, the converter v^U be allowed to perform arbitrary memory 
references to arbitrary forms of memory and no TAXi optimized load exception will be induced. 
When PSW.TAXi_Active 198 is One, the TAXi Optimized Load bit 810 determines 
25 whether a load from a non-zero ASI (i.e. memory not known to be well-behaved) should be 
allowed to complete (TAXi Optimized Load is Zero) or be aborted (TAXi Optimized Load is 
One). A TAXi I/O exception is raised when all three of the following are true: 

1 . PSW.TAXi_Active 198 is One 

2. a memory reference goes through a segment whose TAXi optimized Load bit 810 is 
30 One 

3. the memory reference touches I/O space, that is, the ASI is not Zero 
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Given a mention of an X86 segment in some X86 code, the TAXi translator will sometimes want 
to use a descriptor with TAXi Optimized Load of One and sometimes with TAXi Optimized 
Load 810 Zero. Given an ability to read and write the descriptor register file, and one or more 
spare segment descriptor locations, a properly configxired descriptor can be constructed by 
5 reading the original X86 descriptor location and setting or clearing TAXi Optimized Load 810 as 
appropriate. 

Consider an example, where the TAXi translator uses optimistic assumptions and CSE's 
two loads together, so that only one load instruction actually exists in the TAXi instruction 
stream. The load that is actually optimized is the later load - but it no longer exists in the 

10 optimized instruction stream. Therefore, the remaining load is annotated, even if that load was 
not itself reordered relative to other side effects. When a load actually occurs to I/O space, off a 
TAXi Optimized Load 810 segment, then execution is rolled back to an instruction boundary, 
where all extended Tapestry state is dead. The TAXi code is abandoned, and the original X86 
code is executed in converter 136. Converter 136 will execute the X86 instructions exactly as it 

15 sees them and it will execute every one of the loads (the X86 instruction stream will still be in its 
original unoptimized form, even if the TAXi instruction stream was optimized) so that there will 
be no loads dropped from the stream as emitted by converter 136. 

The TAXi I/O fault is recognized before any side effects of the instruction are committed. 
All TAXi code is kept in wired memory. Thus, no page fault can occur in fetching an 

20 instruction of TAXi code, and any page fault must necessarily involve a data reference. 

As the TAXi code executes, as it crosses from a region translated from one page of X86 
text to another page, it "touches" (a load without use of the result) the corresponding pages of 
X86 instruction text. (The page boundary crossings of the original X86 instruction text, were 
noted in the profile using the mechanism discussed in connection with Figs. 4e and 4f in section 

25 V.D.) This induces page faults in the original X86 code, to provide faithful emulation of the 
execution of the original X86 code. 

After servicing a TAXi I/O exception in the Tapestry operating system 312 and emulator 
316, execution is restarted. In a simple embodiment, the X86 is restored to a previous X86 
instruction boundary, and the restart is always at an X86 instruction boundary. Thus, if a single 

30 X86 instruction has two loads, then translator 124 must take one of two strategies, either (1) 
neither load can be optimized, or (2) both have to be aimotated as optimized. This avoids a 

Atty. Docket No. 30585/28 147 Express Mail Label EI465234796US 

NYDOCS04/ 285781 



situation in which the first load is to non-well-behaved memory and is then re-executed if the 
second load raises a TAXi I/O exception. 

B. Profiling references to non-well-behaved memory 

Referring again to Fig. 4b, memory loads that are directed to anything other than address 
space ID (ASI) zero are recorded in the execution profile (see section V, supra) with a profile 
entry whose event code is 1.11 00. ASI-non-zero references are typically (and conservatively 
assumed to be) directed to I/O space, that is, memory that is not well-behaved, as discussed in 
section I.D, supra. This indication provides a good heuristic for the TAXi translator 124 to 
choose between generating aggressive, optimized code and generating conservative, in-order 
code. 

The initial assumption is that all memory reads are directed to well-behaved (address 
space zero) memory. When converter 136 is running (PSW.ISA indicates X86 mode), and 
profiler 400 is active (TAXi_State.Profile_Active 482 is One, see section V.E and V.F, infra), 
load instructions to I/O space (D-TLB.ASI not equal Zero) that complete cause a "I/O space 
load" profile entry to be stored in a register. The TAXi translator will interpret this profile entry 
to indicate that the optimistic assumption does not hold, and that at least this load must be treated 
under pessimistic assumptions by translator 124, and can be marked with the "safe" setting of the 
segment descriptor "TAXi optimized load" bit discussed in section VIII.A, supra. 

The implementation of this feature somewhat parallels the mechanism used for branch 
prediction. Recall that converter 134, 136 decomposes each X86 instruction into a plurality of 
native Tapestry RISC instructions for execution by Tapestry pipeline 120. When a single X86 
instruction has several memory references, each memory reference is isolated into a discrete 
Tapestry instruction. Even though the Zero/non-Zero ASI value is recorded in the D-TLB, and 
thus can be determined without actually initiating a bus cycle, the address space resolution 
occurs relatively late in the pipeline. Thus, when a reference to a non-zero ASI is detected, the 
Tapestry instructions following the load in the pipeline are flushed. 

TAXi_State.Event_Code_Latch 486, 487 (see section V.E, infra) is updated with the special I/O 
load converter event code 1.1 100 of Fig. 4b. A TAXi instruction to record the I/O space profile 
entry is injected, and the normal profile collection hardware then records an "I/O space load" 
profile entry, in the manner discussed in connection with Figs. 5a and 5b in section V.F, supra. 
Note that this TAXi instruction may be injected in the middle of the recipe for a single X86 
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instruction, where the other TAXi instructions discussed in section V.F are injected at X86 
instruction boundaries. Normal X86 instruction execution resumes in converter 136, and the 
remainder of the instructions in the converter recipe are reinitiated. 

Alternative embodiments might select other classes of instructions for profiling, typically 
5 those instructions that have a high likelihood of raising a synchronous exception, or that have 
some other property of interest to hot spot detector 122 or TAXi translator 124. The number of 
such profiled instructions is kept relatively small, so as not to substantially reduce the density of 
the information made available to hot spot detector 122 or TAXi translator 124, 

10 C. Reconstructing canonical machine state to arrive at a precise boundary 

The code generated by TAXi translator 124 is annotated with information that allows the 

recovery of X86 instruction boundaries. If a single X86 instruction is decomposed into many 
Tapestry instructions, and those Tapestry instructions are reordered by the TAXi optimizer, then 
the annotation allows the end of particular X86 instructions to be identified. The information 

1 5 stored is similar to that emitted by optimizing compilers for use by debuggers. There, the 
instructions of a single source statement are annotated so that source statements can be 
recovered. In TAXi, the annotation allows the recovery of X86 instruction boimdaries from a 
tangled web of Tapestry instructions. Thus, when a synchronous exception is to be exposed to 
the virtual X86, the TAXi run time system establishes a system state equivalent to that which 

20 would prevail at an X86 instruction boundary. Once state is restored to a precise instruction 

boundary, execution can be tendered to converter 136, which in turn can resume execution from 
that instruction boundary. 

In some instances, this annotation mechanism may roll back execution by a considerable 
number of instructions, in order to establish a "safe" state, where all X86 instructions can either 

25 be assumed to have not started, or completed completely. The rollback mechanism avoids 
resuming execution from a state where a single side-effect may be applied twice. 

The code may "checkpoinf ' itself, capturing a self-consistent state snapshot somewhat in 
the manner of a database system. Then, in the event of a fault in the TAXi code, execution can 
be rolled back to the checkpoint, and resumed in converter 136. 

30 
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D, Safety net execution 

Referring again to Fig. 3j, in one alternative embodiment, if this is an asynchronous 
interrupt, case 351 or 354 can allow X86 emulator 316 or converter 136, respectively, to progress 
forward to the next X86 instruction boundary, before delivering the interrupt. In another 

5 alternative embodiment, case 354 can roll back X86 emulator 316 to the previous X86 

instruction boundary. After state is secured to an X86 boundary, execution proceeds through 
X86 operating system 306 as in case 351. In other alternative embodiments, in the case of 
asynchronous interrupts in cases 351, 353, and 354, the code can be allowed to progress forward 
to the next safety net checkpoint before delivering the exception. Each of these are conceptually 

10 similar, in that the virtual X86 310 is "brought to rest" at a stable point at which all Tapestry 
extended context is dead and discardable, and only events whose order is not guaranteed by the 
X86 architecture are allowed to be reordered with respect to each other. 

When an exception occurs in TAXi code and the exception handler determines that it 
must materialize the exception in the X86 virtual machine, it jumps to a common entry in 

1 5 emulator 316 that is responsible for setting the X86 state - establishing the interrupt stack frame, 
accessing the IDT and performing the control transfer. When this function is invoked, it must 
first determine if TAXi code was being executed by examining PSW.TAXi_Active and if so 
jump to a TAXi function that reconstructs the X86 machine state and then re-executes the X86 
instruction in the converter to provoke the same exception again. Re-executing the X86 

20 instruction establishes the correct X86 exception state. Anytime the converter is started to re- 
execute an X86 instruction, the exception handler uses the RFE with probe failed, reload probe 
timer event code to prevent a recursive probe exception from occurring. 

The only exceptions that may not be exposed to the X86 are those that can be completely 
executed by native Tapestry code, e.g., a TLB miss that is satisfied without a page fault, FP 

25 incomplete with no unmasked X86 floating-point exceptions, etc. 

IX. The converter 

Where sections I through VIII focused largely on the TAXi binary translation mode of 

execution, this section IX will focus on a number of techniques used in one embodiment to 
30 improve the implementation of hardware converter 136, during the execution mode in which the 
instructions are translated by hardware converter 136. The techniques of section IX are useful 
when used individually or together. Converter 136, emulator 316, and execution pipeline 120 
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may be used without the techniques of sections I through VIII to implement a CISC processor, 
even without a binary translator 124. The techniques are useful in a dual-instruction-set 
computer, or in a RISC execution engine for emulating a CISC instruction set, or for a RISC 
target for a binary translator from a CISC instruction set, or in a microengine or other 
5 implementation of a CISC instruction set. 

A. Overview 

1. Pipeline structure, and translation recipes 
Fig. 9a presents a hardware-centric view of the X86 branch of the pipeline, in contrast to 

10 the more software-centric view of both the X86 and Tapestry branches presented in Fig. Ic. 
Referring to Fig. 9a, in connection with Fig. Ic, the converter and Tapestry pipeline falls into 
two parts. F-stage (fetch) 110, L-stage (aLign) 130, C-stage (converter) 902, and T-stage 903 
(collectively 134) form an upper part 134 of the pipeline, shovm in the left portion of Fig. Ic and 
the upper portion of Fig. 9a. D-stage (decode) 140 through W-stage 150 form a lower part 120 

15 of the pipeline. 

Lower part 120 includes four relatively conventional RISC pipelines 156, 158, 160, 162, 
with some additional functionality and control that will be elaborated throughout this section IX. 
Lower part 120 of the pipeline executes instructions in order. Dependencies are managed by 
stalls; instructions are not allowed to progress beyond the stage where they consume their source 
20 operands, unless and until those source operands are available. 

In upper part 134 of the pipeline, instructions are fetched. 

If PSW.ISA 194 (see section II, supra) currently specifies native Tapestry mode, the 
fetched instructions are sent directly to lower part 120 (path 138 of Fig. Ic). 

Fig. 9a is largely directed to the case where PSW.ISA 194 currently specifies X86 mode, 
25 in which each fetched X86 instruction is translated into a sequence of one to nine native 

instructions (path 136 of Fig. Ic, stages 110, 902, 903 of Fig. 9a). X86 instruction bytes are 
fetched and aligned in F-stage 110 and L-stage 130. The conversion process is done in two 
stages, C-stage (convert) 902 and T-stage 903. C-stage 902 partially decodes each X86 
instruction and ascertains useftil attributes about it. C-stage 902 decides on one of three 
30 strategies to handle the current set of X86 instruction bytes: (a) if converter 134, 136, 902 knows 
how to execute the current X86 instruction, and the current instruction is not disabled (see the 
discussion of EMUJNST in section IX.A.2, infra), then converter 134, 136, 902 generates 
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Tapestry native instructions to implement the X86 instruction; (b) if converter 134, 136, 902 
cannot itself execute the instruction, it may generate a few native Tapestry instructions to collect 
some information before transferring control to emulator 316; or (c) converter 134, 136, 902 may 
immediately transfer control to emulator 316. 

The translation itself occurs in T-stage 903, in two identical copies of Tapestry 
Instructions Generators TIG il 905 and TIG 12 906. TIG's il 905 and 12 906 decode the opcode 
and address mode bits of each X86 instruction, and based on that decoding, select a "recipe" for 
instructions to be generated. The recipe can be one to nine instructions long. Each of the two 
TIG's 905, 906 can generate two instructions in each cycle. Thus, in each cycle, four 
instructions of a recipe can be generated. For example, if an X86 instruction generates six native 
instructions, TIG iO 905 will generate the first two in the first cycle, TIG il 906 will generate the 
second two in the first cycle, and TIG iO 905 will generate the final two in the second cycle. 
Instruction generators TIG il 905 and TIG 12 906 produce instructions without regard to inter- 
instruction dependencies. These dependencies are managed by issue buffer 907 and D-stage 
140. Instructions are held in issue buffer 907 until all dependencies are resolved. 

Upper part 134 performs the following parts of the instruction decode and processing. 
Branches are predicted. The X86 IP (instruction pointer or program counter) is associated with 
each generated native instruction. The native instructions are given several tags, which will be 
discussed in section IX.A.3, infra. In some timing-critical instances, native instructions are 
partially decoded. 

D-stage (decode) 140 manages issue buffer 907, and determines when instructions have 
satisfied interlock considerations and can be released from issue buffer 907. D-stage 140 
analyzes which instructions are data-independent and can paired in the same machine cycle. D- 
stage 140 ensures that all instructions of a straight-line control flow segment are issued to lower 
pipeline 120 in a continuous sequential stream, and that the branch that breaks the straight-line 
flow segment enters the pipeUne as the last instruction of the stream. 
R-stage 142 reads register operands from the register file. 

A-stage (address generation) 144 performs a number of functions. In the case of memory 
reference native instructions, the address is calculated and the cache access is begun. Simple 
arithmetic logical instructions like "adds" and "ors" are executed in the first and second ALU's. 
A third ALU operates in A-stage 144. Integer multiplies, and floating-point adds and multiplies 
begin execution in A-stage 144, and will continue through E-stage 148. 
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In M-stage 146, the cache access is completed and the output of the cache is aligned. The 
shifter begins its decoding work. Some simple shifts are completed in M-stage 146. 

In E-stage (execute) 148, the result of a memory load is available for bypassing to other 
units. Shifts are completed. A fourth ALU operates in E-stage 148. Multiplies are completed. 
5 Any accumulate associated with a multiply is performed in E-stage 148. Some simple arithmetic 
and logical instructions are performed in E-stage 148, if the instruction does not call for a 
multiply. 

W-stage (write back) 150 writes resuhs, recognizes exceptions, and collects frac 
information (930, discussed in section IX.A.3), as will be discussed in sections IX.A.5 and 

10 IX.C.2, infra. All architecturally-visible side-effects, including exceptions, are deferred until W- 
stage. Any bus transaction, for instance an access to memory attendant to a cache miss, is 
deferred until W-stage 150. Exceptions that arise earlier in the pipeline (divide by zero, raised in 
E-stage 148, or a page fault, raised in A-stage 144, etc.) are not raised as recognized; rather, the 
instruction is tagged (using the side-band information 920 discussed in section IX.A.3, infra) as 

1 5 having raised an exception. The instruction is allowed to progress down the pipeline to W-stage 
150. When the excepted instruction reaches W-stage 150, the exception is may be collected up 
over all instructions of a recipe, or raised immediately. Exceptions on native instructions are 
recognized and acted upon immediately. These may manifest as X86 exceptions, either 
immediately (faults or traps on the last native instruction of a recipe) or delayed until the end of 

20 the recipe (traps on non-last steps of a recipe), as discussed in section IX.A.4, infra. 

Pipe control 910 performs several major fianctions. Pipe control 910 stalls a pipeline 
stage when its source operands are not ready, and allows the stage to proceed when the operands 
come ready. Pipe control 910 controls bypass multiplexers that determines where in the bypass 
tree the source operands are available. Pipe control 910 gathers information about exceptions 

25 from the various execution stages, and coordinates response to those exceptions. This includes, 
for example, detecting mis-predicted branches, and flushing the appropriate stages of the pipeline 
when a mis-prediction is detected. Exceptions are discussed fiirther in section IX.A.4, infra. 

2. The emulator, and the interface between the emulator and converter 

30 Referring to Fig, 9b with Figs, 9a and 3a, hardware converter 136 and software emulator 

316 together, in combination yield a full and faithful implementation of the X86 architecture. 
Converter 136 handles simple instructions. When converter 136 encounters an X86 instruction 
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that is too complex, or that presents complex interactions between instructions, or between 
events and the instruction, or for which hardware conversion has been disabled (see EMU_INST, 
infra), then converter 136 saves some state and passes control to emulator 316 via an exception. 
When a conventional processor takes an exception, the processor state is saved to the 
5 memory stack, and execution vectors to an exception handler. When execution is returned to the 
excepted process, processor state is reloaded from the memory stack. 

However, in Tapestry emulation of the X86, the stack is not available for Tapestry 
internal housekeeping, because Tapestry internal mechanisms are not allowed to use storage that 
is visible to the X86 architecture. Because exceptions are detected by the beginning of W-stage 

10 150, and raised during W-stage 150, but no architecturally-visible side effects are committed 
until the end of W-stage 150, the amount of intermediate pipeline state that must be saved and 
restored on an exception is limited. This information is saved and restored in a collection of 
special-purpose processor registers, called emulator interface registers 912. Emulator interface 
registers 912 contain enough information about the X86 instruction that emulator 316 can, if 

15 needed, refetch the X86 instruction, and decode it itself Emulator interface registers 912 are 
loaded when invoking emulation of a complex instruction, and are generally not meaningful for 
other exceptions. 

Information is stored in emulator interface registers 912 on several classes of events. 
Hardware converter 136 may pass control to emulator 316, either because the instruction is not 

20 implemented in the converter hardware 136, or because the instruction has been disabled in 

EMU_INST, or for other reasons. The information stored in interface registers 912 is generally 
dependent on the instruction being emulated, and is generally directed to providing information 
to improve the efficiency of emulator 316, or handing off information from converter 136 to 
emulator 316. Some emulator interface registers 912 may not contain useful information in 

25 some cases. 

When an instruction is not handled completely by converter 136, converter 136 avoids 
updating any X86 architectural state before passing control to emulator 316. 

The transfer to emulator 316 is effected in C-stage 902, so the fetch of the first instruction 
from emulator 316 occurs while the emulated X86 instruction is in D-stage 140. 
30 In addition to emulator interface registers 912, EPC register 914 contains an image of the 

machine program status word (PSW) and the X86 program counter (IP). EPC register 914 
contains the following bit flags, among other information: 
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Table 7 - EPC register 


UK 


select between user and kernel mode 


IE 


fflobal intetnint enable for maskable nrnressor and software 
interrupts 


ISA 


bit 194 — enable the converter / TSA nacre nronertv hit <3et to 
the ISA bit of the target Dase bv a control transfer instruction 


XP 


EPC image of XP bits 184, 186 , as discussed in section I.F 


STEP 


single- step mode 


EM86 


X86 emulator context is current! v active 


AC 


allow alignment checks analocrous to the AP bit in the ^Rf^ 
EFLAGS 


V86MODE 


virtual X86 mode analnpniis tn the VSfi bit in thp YRf, FFT AG^ 


RF 


resume flag, inhibit breakpoints - analogous to the AC bit in the 
X86 EFLAGS 


TA^i Artive 




PROBE_ENABLED 


see section VI 




imdge oi uie enu-oi-recipe marKer yzo^ maicaung inai ine processor 
is at an X86 instruction boundary, discussed at sections IX.A.3 


TRANSFER 


ine L^iJiN iKUL_iKAiN or t/K Dit IS moaiiieu Dy every mstruction 
execution, set to One if and only if the previous instruction was a 
lojvcn couLioi Lidnsier insuruciion. 


P_TRACEPOINT 


software controlled read/write bit; used to record a pending 

trapenoint trfin 

LlClV^WUUlllU tlCllJ 


P_STEP 


software controlled read/write bit; used to record a pending X86 
single-step trap 


FRAC (4 bits) 


image of the frac bits 930, discussed at sections IX.A.3 and IX.A.5, 
infra 


EIP (32 bits) 


the offset into the code segment for the current X86 instruction (in 
the case of a fault) or the next instruction (in the case of a trap) 



The PCW (Processor Configuration Word) stores a collection of processor state that does 
not change across exceptions. This state includes processor and software interrupt enable 
modes, software interrupt request modes, code and data segments to use during exceptions, 
exception execution enable modes, X86 modes for defaults code/data/stack size, protected mode, 
X86 running mode, alignment checks, kernel write protect mode, and memory proxy. The bits in 



the PCW are managed by emulator 316 and Tapestry operating system 312. Among the bits in 
the PCW are the following: 



Table 8 -PCW register 


HWIE 


several bits enabling hardware interrupts 


SWIE 


several bits enabling software interrupts 


SWI 


several bits indicating pending software interrupts 
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EX_ESEG 


4 bits, holds the value loaded into PC.ESEGP, indicating the 

exception execution (code) segment descnptor pointer, when an 
exception occurs 


EX_DSEG 


4 bits, holds the value loaded into PC.DSEGP, indicating the 
exception data segment descriptor pointer, when an exception occurs 



The Tapestry architecture provides additional emulator interface registers 912 as follows. 
These registers are set when converter 136 traps to emulator 316. 



Table 9 - Emulator interface registers 


EMU_ASIZE 


read/write 
1 bit 


specifies the effective address size, taking into account the 

VailU.iljf' \Jl LllC U aXlKX D UlLo, cUlU ally UVClIlClC prCilXcS. ZjCIU 

indicates a 16 bit effective address, One indicates a 32-bit 
effective address. 




iCaCL/ WllLC 

11 bits 


apcuiiicb a Ddbc regis ler dnci dii luuex register, anu a snin 
count derived from the modrm and SIB bytes for how to 
generate a memory address of the instruction. Both register 
values are optional - one bit fields determine whether the 
register specifiers are valid or not. 


EMU_CIP 


read/write 
32 bits 


the instruction pointer of the current X86 instruction, as an 
offset into the x86 code segment. 


EMU_NIP 


read/write 
32 bits 


the instruction pointer of the next X86 instruction, as an 
offset into the x86 code segment. 


EMU_DISP 


read/write 
32 bits 


the displacement for a memory reference, sign-extended to 
32 bits. If the instruction contains no displacement, then 
EMU DISP contains Zero. 


EMUJMM 


read/write 
32 bits 


the instruction's immediate value, sign-extended to 32 bits. 
If the instruction contains no immediate, then EMU_IMM 
contains Zero. 


EMUJNST 


read/write 
64 bits 


EMU INST bits, when set, specify which X86 instruction 
classes should not be converted by converter 136. When an 
EMU_INST bit is set, instructions of a corresponding class 
die execuieu in emuiaior .^lo msieaa. ii me processor 
attempts to decode an X86 instruction in a class whose 
corresponding EMU INST bit is set, the processor fauhs to 
VECT_RESERVED_X86. EMUJNST is examined only 
when converter 136 is active; emulated instructions are not 
affected by the setting of EMUJNST. Instructions are 
divided into twelve classes by opcode, thirty-three classes by 
operand class (MMX instructions with and without an 
immediate, MMX instructions with an immediate, integer 
read-execute- write instructions with and without an 
immediate, integer read-execute instructions with and 
without an immediate, integer non-memory ALU 
instructions with an immediate, instructions that v^ite 
segment registers, conditional branches, etc.), and nineteen 
groups according to compatibility and prefixes (floating- 
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point, floating-point stack-modifying instruction, integer 
hidden opcodes, XCHG instructions with implicit lock 
behavior, etc.). Many X86 instructions are covered by bits in 
more than one of these groups; an instruction is executed in 
converter 136 only if all of the EMU_INST bits affecting it 
are deasserted. 


EMU__LENGTH 


read/write 
4 bits 


X86 instruction length, including prefixes, as a byte count. 


EMU_LOCK 


read/write 
1 bit 


set if the instruction had a lock prefix associated with it 


EMU_OPC 


read/write 
8 bits 


contains the first meaningful X86 instruction opcode byte. 
This is usually the first byte following the last prefix byte. If 
this first byte is 0Fi6, then EMU_OPC contains the second 
byte following the last prefix. 


EMU_OPC_0F 


read/write 
Ibit 


set if the fist byte of the instruction opcode was 0Fi6 


EMU_OSIZE 


read/write 
1 bit 


specifies the effective operand size, taking into account the 
D bit, and any override prefixes. Zero indicates a 16 bit 
operand. One indicates a 32-bit operand. 


EMU__REP 


read/write 
2 bits 


species what type of repeat prefix was used for the current 
instruction: none, REP/REPE/REPZ or REPNE/REPNZ 


EMU_RM_20 


read/write 
3 bits 


a copy of bits <2:0> of the instruction's modrm byte 


EMU_RM_53 


read/write 
3 bits 


a copy of bits <5:3> of the instruction's modrm byte 


EMU_RM_76 


read/write 
2 bits 


a copy of bits <7:6> of the instruction's modrm byte 


EMU_RM_RR 


read/write 
1 bit 


a single bit that specifies whether the two most-significant 
bits of the instruction's modrm byte are both One 


EMU_SEG 


read/write 
3 bits 


identifies the effective segment (GS, FS, DS, SS, CS, or ES) 
used for a data reference after taking into account the default 
segment and segment override prefixes 


EMU SIB 

BASE 


read/write 
3 bits 


a copy of bits <2:0> of the instruction's SIB byte 


EMU SIB 

INDEX 


read/write 
3 bits 


a copy of bits <5:3> of the instruction's SIB byte 


EMU SIB 

SCALE 


read/write 
2 bits 


a copy of bits <7:6> of the instruction's SIB byte 


EMU REGl, 
EMU REG2 


32 bits 


The following information is stored only for some of the 
instructions that are always emulated. If an instruction 
is usually not emulated, but converter 136 have been 
asked to emulate it for some reason, then this 
information is not generated for these instructions. 

Any instruction that cannot be completely handled by 
hardware converter 136 will not modify any X86 
architectural state before transferring control to emulator 
316. EMU_REG1 and EMU_REG2 capture the results 
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of partial execution in converter 136 before execution is 
transferred to emulator 316. 
If the emulated instruction has to do both a load and a store, 
or if the emulated instruction only has to do a store, or if 
memory load cannot be performed in converter 136 
because the load would affect architectural state, then 
the EMU REGl and EMU REG2 registers contain the 
memory address offset and the segment base for the 
memory operand. SEG CONVS (another processor 
register) conveys the segment used by the memory 
reference. 

If converter 136 is providing the operands, either form 
memory or from registers, then EMU REGl and 
EMU_REG2 v^ill contain the first and second operands 
of the instruction. Converter 136 will generate 
instructions to load either operand from memory. It will 
also move a register or immediate operand in 
EMU__REG1 or EMU__REG2 as appropriate. 

If converter 136 causes an exception in the process of 

performing the preliminary execution of an instruction 
to be completed in emulator 316, then control will be 
passed to the appropriate exception handler and not to 
the emulator entry point. 



Other processor registers 914 capture the X86 interrupt flags, and the X86 EFLAGS and 
condition codes. 

Together, these emulator interface registers 912 and EPC 914 provide one instruction's 
5 worth of historical context. This corresponds to a one deep exception stack implemented with a 
processor register. As shown in Table 7 and discussed in sections IX.A.3 and IX.A.5, infra, the 
intra-instruction PC ("frac bits" 930) is also captured in EPC register 914. Even if the interrupt 
occurs within an X86 instruction, the exception occurs at a precise boundary between two 
Tapestry instructions. On an exception, the information that would conventionally be spilled to 

1 0 the memory stack in an exception frame is architecturally committed in emulator interface 
registers 912 and EPC 914, the Tapestry general purpose registers, plus the FP-IP/OP/DP 
registers (discussed in section IX.C.2). Thus, a software exception handler has access to the full 
intermediate state of any partially-executed X86 instruction, and can restart the instruction for 
the point of the interrupt, all without recourse to a memory exception frame. By examining the 

1 5 frac bits 930 intra-instruction PC, emulator 316 can determine exactly where the X86 instruction 
was interrupted, and therefore associate Tapestry registers to corresponding X86 operands, etc. 
Though the emulator/converter interface is designed (with few exceptions) so that emulator 316 
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does not need to know where in the recipe an exception is signaled, the FRAC bits make this 
information available. 

Emulator 316 can return to converter 136 in three places. First, when emulation of an 
emulated instruction has completed, control will be passed back to the next X86 instruction by 
5 setting the instruction pointer to the value in EMU_NIP (next IP, Table 9). Second, when 

emulating a control transfer instruction, emulator 316 sets the instruction pointer appropriately to 
the target destination of the control transfer instruction. Third, after an exception, emulator 316 
may either go back to the instruction that raised the exception, or to the next instruction, or to an 
X86 exception target, depending on the exception.. 

10 Complex CISC instructions are handled by basically the same pipeline and architectural 

infrastructure already extant to handle exceptions. When converter 136 encounters a complex 
instruction to be handled by emulator 316, converter 136 saves information in emulator interface 
registers 912 and EPC 914. Converter 136 then issues an "effective" TRAP instruction to 
pipeline 120. The TRAP instruction has an argument, a trap vector number (e.g., one of the 

1 5 emulator trap vectors) that selects a handler to be executed; the argument may depend upon a 
particular instruction or major machine mode. The TRAP instruction transfers execution to 
emulator 316. The TRAP argument is used to select a routine in emulator 316, The selected 
routine performs the work of the complex instruction, on behalf of converter hardware 136. The 
selected emulation routine is controlled by the contents of the emulator interface registers 912 

20 and EPC 914. Some handlers in emulator 316 use emulator interface registers 912 and EPC 914 
as read-only information to decide what to do. Some handlers write results into emulator 
interface registers 912 and EPC 914. At the end of the emulation routine, an RFE instruction 
returns execution to the converter 136. Machine state is reestablished based on the information 
in emulator interface registers 912 and EPC 914, either the information that was put there at the 

25 time of the exception, or the information as altered by the handler. 

It is desirable that native Tapestry instructions in the pipeline be context insensitive, with 
respect to whether they were from a native Tapestry binary, or generated by converter 136, with 
respect to the X86 instruction from which they were generated, and with respect to the location 
within an X86 recipe. In order to promote that context independence in the face of certain X86 

30 complexities, for instance debugging, emulator 316 is occasionally triggered during the middle 
of a recipe in order to convey machine state from one Tapestry instruction to the next, or to 
collect all of the results of a single X86 instruction. 
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Consider the case of an X86 MOV instruction, from memory to a general purpose 
register. The recipe for this X86 instruction is a single native instruction, a load. The memory 
load operation must only be issued as a bus transaction only once, because the memory load may 
be directed to I/O space, and will change processor state if retried. The memory load goes 
5 through the segmentation and paging translation hardware. If, for instance, there is a TLB miss 
on the memory load, then execution of the load is prevented; the X86 EIP information and frac 
bits 930 are stored to preserve the context in which the instruction will be restarted. (Frac bits 
930 and restart from the middle of an X86 instruction are discussed in more detail in section 
IX.A.3 and IX.A.5, infra) Execution vectors to the TLB miss handler. Eventually, execution is 
10 resumed in the converter. Because the recipe is a single instruction, the recipe is resumed from 
the beginning. The load never progressed beyond the TLB, but now it can be issued as a bus 
transaction. 

The hardware exception vectoring mechanism in the pipeline control for traps and faults 
is relatively uniform, whether the exception is to be handled by emulator 316, by the Tapestry 

1 5 operating system (312 of Fig, 3a), or by the X86 operating system 306. Thus, the hardware has 
little knowledge of emulator 316 or its function; to the hardware, emulator 316 is just another 
exception handler. The differences are confined to the software itself. For instance, on entry to 
emulator 316, a special handshake in hardware preserves emulator interface registers 912 and 
EPC 914 to capture the state of X86 converter 136, and turns off converter 136 and enters native 

20 mode. From the hardware's point of view, there is little difference between invoking emulator 
316 to handle a complex instruction, or invoking emulator 316 or another exception handler to 
handle an exception in an instruction that was initially processed by converter 136. 

Emulator interface registers 912, 914 are collected at the boundary between C-stage 902 
and T-stage 903. In one embodiment, emulator interface registers 912, 914 are pipelined, and 

25 the information stages down the pipe with the corresponding native instruction. 

In another embodiment, even though the machine is pipelined and speculative, the 
following protocol allows emulator interface registers 912, 914 to store the required information 
in only one set of registers. Emulator interface registers 912, 914 may be in one of two states: a 
load state and a protected state. Registers 912, 914 transition from the load state to the protected 

30 state when a pseudo TRAP instruction is received from X86 instruction decoder 929, and 
transitions from the protected state to the load state on a pipeline flush. (Pipeline flushes are 
invoked when a branch mis-predict is detected for either address or direction, on any far transfer, 
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including an RFE, TRAP or an exception vector, and on writes to certain processor resources, 
etc.) Even if the pipeline flush occurs during execution of emulator 316, the emulator interface 
registers 912, 914 will remain frozen, because emulator 316 itself is in Tapestry native code - 
X86 decoder 929 will remain quiescent and cannot drive emulator interface registers 912, 914, 
5 In the load state, the X86 instruction decoder 929 drives emulator interface registers 912, 914 
with new values as each X86 instruction is decoded. In the protected state, emulator interface 
registers 912, 914 do not automatically update, but are only loaded by an explicit write into the 
processor register. As long as the processor is executing a sequence of converted instructions, 
emulator 316 will not be invoked to read emulator interface registers 912, 914, so the values 
10 need not be staged down pipeline 120. When emulator 316 is to be invoked, the condition is 
detected early enough so that emulator interface registers 912, 914 can be preserved until they 
will be required. 

An example of this operation follows. 

X86 decoder 929 is able to determine, by the end of C-stage 902 and the beginning of T- 

1 5 stage 903, whether the instruction will trigger an entry to emulator 316 - in fact, decoder 929 
will emit a pseudo TRAP instruction. The contents of emulator interface registers 912, 914 are 
protected during execution of emulator 316, so that emulator 316 can read emulator interface 
registers 912, 914 as it does its work. When decoder 929 encounters an instruction that will be 
emulated, the processor immediately freezes further writing of emulator interface registers 912, 

20 914 by X86 decoder 929, so that the value of emulator interface registers 912, 914 will be 

protected until emulator 316 is entered. In one implementation, the pseudo TRAP instruction is 
recognized at entry into T-stage 903, and this triggers feedback into C-stage 902 to freeze 
emulator interface registers 912, 914 in protected state. Emulator interface registers 912, 914 
remain protected while the pseudo TRAP flows down pipeline 120, while emulator 316 executes. 

25 During execution of emulator 316, X86 decoder 929 is turned off so there is no new information 
to load in emulator interface registers 912, 914. When emulator 316 completes, emulator 316 
exits with an RFE (retum from exception) instruction; the definition of the RFE instruction calls 
for a pipeline flush. That flush causes emulator interface registers 912, 914 to transition back to 
the load state. If the target of the RFE is an X86 instruction, whether converted or emulated, 

30 emulator interface registers 912, 914 will be loaded on each subsequent instruction decode. 

This protocol works even if emulator 316 is invoked on an exception that will be 
reflected by entry into the X86 operating system 306 before execution returns to the interrupted 
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code. In this embodiment, emulator interface registers 912, 914 only carry information relevant 
to the internal operation of an X86 instruction boundary - no information need be carried across 
an X86 instruction boundary. At entry to X86 operating system 306, the processor is necessarily 
at an X86 instruction boundary, so the information in emulator interface registers 912, 914 is 
5 dead. Once within X86 operating system 306, the instructions are, by definition, coded in the 
X86 instruction set, and these instructions are either converted or emulated. If these instructions 
are converted, then emulator interface registers 912, 914 are overwritten on every X86 
instruction, and the values are correct. If an instruction of X86 operating system 306 is 
emulated, including one that may ultimately may resolve in running some entirely different piece 

10 of code, the emulation will always end with an RFE instruction; if that RFE returns to X86 code, 
that instruction will either be converted or emulated, and thus emulator interface registers 912, 
914 v^U be handled correctly on exit from X86 operating system 306. 

The combination of techniques described in this section IX (including the instruction 
pointer and frac bits 930 of section IX.A.3, emulator interface registers 912 and EPC 914 of 

15 section IX.A.2, and the temporary registers discussed in section IX.B.l) ensures that the context 
that needs to be captured on an exception is in fact available for inspection by Tapestry system 
software 312, 316, even without a dump of pipeline state onto the stack. X86 intermediate 
information that would snapshotted to the stack in a conventional processor is instead exposed in 
Tapestry architectural state 912, 914. Native Tapestry execution in emulator 316 or Tapestry 

20 operating system 312 does not update emulator interface registers 912, and thus this context 
information can be captured by emulator 316. Because EPC 914 is shared between all 
exceptions (TLB miss, for example), emulator 316 preserves EPC 914 by writing it to memory 
when there is the possibility of another exception being signaled. The temporary registers and 
X86 emulator interface registers 912, 914 are part of the extended context (native Tapestry 

25 context that is outside the view of the X86) that is managed among X86 processes using the 
context management techniques described in section III, supra. Any additional information 
required to restart an X86 instruction can be derived from the saved instruction pointer and frac 
bits 930. 

Execution of the TLB miss handler may evict the excepted X86 instruction from I-cache 
30 112; on resumption, the instruction fetch may miss in I-cache 112. For instructions stored in 
cacheable memory, there is no unintended side-effect. For instructions stored in non-cacheable 
memory, an additional memory reference may occur. 
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3, Side-band information: frac bits, instruction boundaries, 
interruptible points, etc. 

Referring to Figs. 9c and 9d in conjunction with Fig, 9a, as each instruction is staged 
5 down the pipe, it may be accompanied by several bits 920 of aimotation and status information 
developed during the conversion to native instructions. These additional bits 920 are called 
"side-band" information. Side-band information 920 is developed in upper portion 134 for X86 
instructions, indicated by arrow 922 feeding from TIG's 905, 906 into pipe control 910 and 
arrows 923 from pipe control 910 to the execution units of the pipelines. During native mode 

10 execution, side-band information 920 is also developed as 32-bit instructions are decoded in 
native-mode decoder (132, 138 of Fig. Ic). The full instruction, with its side-band complement 
920, is called a "formatted instruction." 

The native instruction format architecturally exposed (e.g., to assembly language 
programmers) has a 6-bit field for load/store displacements, arithmetic/logical immediates, and 

15 PC-relative branch displacements. The X86 provides for eight-bit, sixteen-bit, and thirty-two-bit 
immediates and displacements. TIG's 905, 906 and the native Tapestry instruction decoder 132, 
138 expand these displacements and immediates to thirty-two bits 924. In some embodiments, 
the internal Tapestry instruction has both a thirty-two bit immediate field and a thirty-two bit 
displacement field. This expanded displacement and/or immediate 924 stages down the pipeline 

20 as side-band information to the native instruction. The instructions in lower part 120 of the 
pipeline are otherwise the same as the architecturally-exposed native Tapestry instructions. 

The multiple instruction generators 905, 906, operate on a single X86 instruction at a 
time, and together can generate up to four native Tapestry instructions from that X86 instruction. 
Each native instruction is tagged with a marker indicating the IP value for the X86 instruction 

25 from which it originated. In one simple embodiment, each instruction carries the thirty-two bit 
value of its IP plus four frac bits 930 (frac bits 930 will be explained later in this section IX.A.3). 
In another embodiment, a set of thirty-two IP value registers are provided (for the eight pipeline 
stages, times four pipelines), each holding an X86 IP value. Each native instruction of a recipe 
carries a pointer to the IP value register holding the IP value of the X86 instruction from which 

30 the native instruction was translated. As the last instruction of a recipe is retired, the IP value 
register for the X86 instruction is freed. As an X86 instruction enters the converter, one of the 
free IP value registers is allocated, and stamped with the current X86 IP value. 
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In another embodiment, the instruction pointer marker is optimized to recognize certain 
constraints on the order in which instructions are generated by converter 136. As instructions 
flow down the pipeUne, the instructions are maintained in bottom-to-top, left-to-right order. 
Branches are all in the right-most pipeline. Thus, in each horizontal slice of the pipeline, all 
5 instructions are in order, reflecting part of a sequential flow. A branch instruction is always the 
youngest instruction in a pipeline stage. Thus, the IP for every instruction in a given stage will 
be equal to the IP value of the instruction in the left-most pipeline, plus at most forty-five (three 
additional sequential X86 instructions, each at most fifteen bytes long). In this embodiment, 
each stage 140-150 carries the IP value of the leftmost instruction (the PC column 925), and the 

10 instructions in the other three pipes each carry an accumulated instruction length value. The sum 
of the PC 925 for the stage plus the accumulated instruction length gives the IP value for the 
corresponding instruction. 

In another embodiment, each instruction carries a length. Reading across, the IP value is 
incremented by the length count after each instruction that is marked with an end-of-recipe 

15 marker (discussed next). Each instruction in the sequential group (iO-i3) traveling down the four 
pipelines 156-162 together has an instruction length of zero to fifteen. In the top of the pipe 134, 
the length of the X86 instruction is tagged onto the last instruction of each X86 recipe, and the 
non-final 7926 native instructions have their length tags set to zero. 

The native instructions in the D- through W-stages 140-150 of the pipeline carry markers 

20 926 to indicate the last instruction in a recipe for each X86 instruction. The end-of-recipe 

marker on each instruction is called X86_COMPLETED 926. This indication is used to denote 
instruction boundaries, which in turn is used to control single-stepping, to designate points at 
which execution can be interrupted, etc., as will be discussed in sections IX.C to IX.E. 

The X86 is also interruptible at certain points during the partial execution of certain long- 

25 running instructions. For instance, X86 string instructions can be interrupted at certain iteration 
boundaries, with architecturally- visible state that changes once per operand of the string, such as 
the address of the current byte of a string move or compare. The X86 allows such instructions to 
be interrupted, or to be single-stepped within the partially-executed instruction, and then resumed 
using the normally visible X86 state. The native instructions in D- through W-stages 140-150 of 

30 the pipeline carry markers 990 indicating these interruptible points. These end-of recipe markers 
926 and interruptible iteration boundary markers 990 are used in W-stage 150 to raise interrupts 
at appropriate times, as discussed infira in section IX.C. 
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Each Tapestry instruction carries an exception tag 927. If the instruction has raised an 
exception, tag 927 carries the value of the highest priority exception vector. Each execution 
pipeline, and each stage within each pipeline, has an exception tag 927. The particular format is 
unique to each pipeline, since each pipeline may detect different exceptions. Most pipelines 
5 simply store a unique identifier similar to the vector number. This exception information flows 
down the pipelines with the instructions. In E-stage 148 the last exception information is 
obtained. The E-stage information for all pipelines is prioritized by age, selecting the oldest 
instruction with any actionable exceptions. The exceptions for this single instruction are again 
prioritized by architectural priority. The highest priority exception is raised, and the remainder 
10 are queued. 

The APC column 928 for the stage indicates the "altemate PC," the instruction pointer 
for the alternate path associated with the at most one branch in the group in this stage. In the 
case where a branch is predicted taken, the alternate PC is the sequential PC, the instruction 
following the branch. In the case of a branch that is predicted not taken, the APC is the target of 

15 the branch. (Recall that there can only be one branch in any pipeline stage, so a single APC 
suffices to cover the four instructions of the stage.) If at any time a branch is determined to be 
mis-predicted, the pipelines are flushed of all younger instructions, and execution resumes at the 
instruction designated by APC 928. 

The side-band 920 also contains information related to X86 instruction control 

20 information, for instance, indicating whether a particular native instruction in the recipe has a 
hardware interrupt, or a single-step exception associated with it. The side-band 920 is also used 
to control a number of features of the X86 floating-point implementation, for instance the 
floating-point stack tag map, floating-point data and instruction pointers, and floating-point 
opcode information. Side-band information 920 includes state from the converter for managing 

25 the mapping between the X86 floating-point stack and the native Tapestry flat register file. For 
example, when an instruction pushes or pops information on or off the X86 floating-point stack, 
the converter manages the changes to that map within upper part 134 of the pipeline using side- 
band information 920. On a context switch or during an emulated instruction where the map 
needs to be completely changed, the new map information is communicated between the 

30 execution units and converter 134 using side-band information 920. 

As each native Tapestry instruction is generated by instruction generators 905, 906 in T- 
stage 903 into issue buffer 907 for execution down pipeline 120, the instruction is tagged with a 
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four-bit sequence number, from zero to fifteen, denoting the sequential position of that native 
instruction in the recipe for the X86 instruction from which it originated. This four-bit sequence 
number is called the "frac bits" 930. Frac bits 930 are used to restart a partially-completed X86 
instruction after an exception, as described in fiirther detail in section IX.A.5, infra, Frac register 
5 931 is a counter that counts up from Zero as each native instruction is generated, and reset to 
Zero at the completion of X86 instruction, to generate frac bits 930 for the corresponding native 
instruction. Frac control logic 932 increments frac register 931, to count off native instructions, 
and feeds the count to the instruction generators 905, 906. Instruction generators 905, 906, in 
turn, tag the instructions with the frac values 930 as the instructions are fed to issue buffer 907. 

10 There are two classes of upward-flowing side-band information, data and control flow. 

Control flow side-band information indicates that "the lower part of the pipeline is being 
flushed," or "the entire pipeline is being flushed, including upper part 134," and the new program 
counter at which to resume execution. Specific instances of this upward-flowing control flow 
will be discussed in sections IX.B.6 and IX.B.7, infra, 

1 5 Additional side-band information is shown in Fig. 9d. Two specific elements of side- 

band 920 are discussed in sections IX.A.6 (relating to load and store instructions) and IX.C.2 
(relating to floating-point information), infra. 

4. Interrupts, traps, and exceptions 

20 X86 exceptions are reported at the granularity of X86 instructions 926 or interruptible 

points 990. Native exceptions (hardware interrupts, execution faults and traps) may be signaled 

on any native instruction boundary, even when this native instruction is part of an X86 recipe. 

X86 exceptions, however, appear to the X86 programmer as occurring on X86 boundaries 926. 

This does not require the complete execution of all the native instructions in the recipe. Instead, 
25 X86 faults are surfaced as soon as the corresponding native fault is recognized, without 

completing later instructions in the recipe. X86 traps, however, are postponed (by emulator 316) 

until completion of all the native instructions in the recipe. This section IX.A.4 is addressed 

primarily to X86 exceptions. 

There are two kinds of exceptions: faults and traps. Faults unwind the X86 instruction's 
30 execution, except for side-effects particular to the exception. Traps are deferred until the X86 

instruction completes. Faults and traps can be signaled on individual native instructions of a 

recipe. 
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In overview, an exception is recognized and processed in the following steps: 



1 . Save information (primarily relating to cause of the exception and context at the time of 
the exception) in emulator interface registers 914, 916 so that emulator 316 and any 
5 other exception handler 306 can determine the cause of the exception. 



2. Save the current state in the EPC register. This includes: 

- EIP of the current instruction (fault or interrupt) or the next instruction (trap) 

- PSW register contents (after possible side effects and modifications for transition 
10 exceptions) 

- frac bits (see section IX.A3), the data segment pointer and the code segment pointer 



3. Compute the exception context, as shown in the following pseudocode (see Table 7). In 
the process of entering the exception context, the machine is placed in a more privileged 
1 5 state and protected from further exceptions. 

- Exceptions are handled in Tapestry native mode with kemel access enabled. 

- Alignment checks, interrupts, the resume flag, binary translation, and the Instruction 

Converter Unit are disabled. 



20 PC.ESEGP :=PCW.EX__ESEGP 

PC.DSEGP := PCW.EX_DSEGP 
PC.FRAC :=zero 
EPC := { 

UK kemel 
25 IE := disabled 

ISA := native 
XP := native 

STEP := STEP or ERROR exception 
EM86 asserted if emulator exception 
30 AC := disabled 

RF :- disabled 
TAXI_ACTIVE := inactive 
X86_COMPLETED :- not last 
CONTROL_TRANSFER := not a taken 

35 } 

PC.EIP := vector for the exception ID 

4. Release any active memory locks (deassert LOCK_ADDR_*). 

40 5. Signal a single-step exception, if required. 

6. Fetch the next instruction 
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An exception may arise during execution of a native thread that is to be surfaced to X86 
operating system 306. In some instances, Tapestry operating system 312 may signal the X86 
operating system 306 to start up a thread, so that the X86 thread can receive the interrupt. 

To return from exception, the privileged RFE (Return From Exception) instruction is 
5 executed. The processor is instructed by RFE to copy the contents of the EPC to the PC and 
PSW registers. The steps involved in the return are described belov^: 

1 . Restore previous context: 

PC.ESEGP :=EPC.ESEGP 
10 PC.DSEGP :=EPC.DSEGP 

PC.FRAC ~ EPC.FRAC 
PC.PSW := EPC.PSW_image 
PC.EIP EPC.EIP 

15 2. If the appropriate bit in the RFE is asserted, signal any pending traps 

3 . Fetch next instruction. 

Specific applications of this general approach are discussed below. 

20 For some fault classes (for instance, the LOOP instruction discussed in section IX.B.6, 

below, and condition code restoration for page faults), emulator 316 unwinds the entire X86 
instruction, and surfaces the fault to the X86. For other fault classes, for instance a TLB miss, 
emulator 316 services the fault, and then continues on in the recipe, retrying the faulted native 
instruction, using frac bits 930 to determine the native instruction at which to resume. When the 

25 fault is to be surfaced to X86 operating system 306, emulator 316 builds an X86 compatible 
stack frame, including (in some situations) an error code. 

A trap in a non-final native instruction /926 corresponds conceptually to an exception in 
the middle of the X86 instruction. Because exceptions are only surfaced to the X86 environment 
at an X86 instruction boundary 926 (or interruptible point 990), the remaining instructions of the 

30 recipe are completed (possibly invoking a handler in emulator 316) before the exception is 

surfaced to the X86 environment. For instance, an address comparison in the debug hardware 
generates an immediate trap into emulator 316, where the trap handler collects information to be 
reported. Then execution of the recipe resumes, and at the end of the X86 instruction, the trap is 
usually surfaced to the X86 environment. A trap on a final native instruction 926 of a recipe is 
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typically surfaced to the X86 environment. For instance, an X86 single-step exception is 
typically raised on the final native instruction 926 of a recipe. 

When an excepted instruction, with its exception tag 927, reaches W-stage 150, "frac 
update" control logic 933 responds. If the exception requires an immediate response on the 
5 Tapestry instruction that raised the exception 926 (any exception on the final instruction of a 
recipe, or a fault), then the exception is raised immediately, and execution vectors into emulator 
316 for intra-instruction repair of the fault, as discussed in section IX.A.2, supra. If the 
exception is a trap on a non-final instruction 7926 of a recipe, the native machine responds 
immediately to the exception, on a native instruction boundary, but emulator 316 defers response 

10 to the next X86 instruction boundary 926 or next interruptible point of the X86 instruction. If an 
X86 exception (trap) must be delayed across multiple native instructions to reach the end of the 
X86 instruction, then in one embodiment, emulator 316 uses the X86 single-step facility to effect 
the delay, in the manner discussed in section IX.C, infra. In another embodiment, the exception 
is held pending in frac update logic 933, and execution is allowed to progress forward to the end 

15 of the cxorrent instruction's recipe, or to the next interruptible point. In either embodiment, if this 
forward progress reaches the end 926 of the current X86 instruction, the IP value is incremented 
to point to the next instruction, and firac register 931 is cleared to Zero to indicate the begiiming 
of the next instruction, thereby emulating the IP value exposed by the X86. The collected 
exceptions are raised, and execution traps into emulator 316. If the exceptions can be handled by 

20 emulator 316, execution continues. If emulator 316 cannot correct the exception, emulator 316 
builds an X86 exception frame on the stack, and vectors control to X86 operating system 306. 

Some single-step exceptions are introduced by emulator 316 to gain control at the next 
X86 instruction boimdary 926 to trigger further work in emulator 316. There are situations 
where emulator 316 (either through direct entry via an instruction not processed by the converter, 

25 for example, the STI instruction, as discussed in section IX.E.2, or on behalf of an exception, or 
debug address match, as discussed in section IX.C.l) must delay processing the exception, or 
intervene with additional processing at the next X86 instruction boundary. The single-step 
mechanism is used to move forward to this boundary. When the exception is initially raised 
Converter 136 vectors into emulator 316, and emulator 316 in turn enables the X86 single-step 

30 exception so that emulator 316 will regain control at the next X86 instruction boundary. When 
the next X86 instruction boundary 926 is reached, an X86 single-step exception vectors into 
emulator 316, which in turn performs the processing requested by the earlier exception, or 
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handles the condition that was raised in the middle of the X86 instraction. Specific examples of 
this mechanism will be discussed in sections IX.C.l and IX.E^, infra. 

Emulator 316 is invoked by exception in other instances, as well. For instance, when an 
X86 instruction calls for writing the X86 interrupt flags, converter 136 generates a single-step 
5 trap into emulator 316. Emulator 316 writes the interrupt flag value into an emulator interface 
register 912. That value is loaded from the interrupt flag emulator interface register 912 into the 
actual processor registers when emulator 316 RFE's back to the converter. As another example, 
modifications to the X86 interrupt flag (the IE bit of Table 7) are always emulated - the IE bit is 
only written by emulator 316, never by converter 136. Emulator 316 activates single-step mode 

10 to gain control at the next X86 instruction boundary, specifically to inhibit the reporting of 
certain exceptions. Other examples of emulator functions invoked by exception will be 
discussed throughout this section IX. 

When converter 136 encounters a complex X86 instruction, it inserts an explicit TRAP 
instruction into the pipeline to force entry into emulator 316, as discussed in section IX.A.2, 

15 supra. For all other exceptions, no explicit TRAP instruction is emitted by converter 136; rather, 
the hardware forces initiation of exception vectoring. 

The native hardware is designed so that some hardware interrupts will be delivered to the 
X86 environment, and others will be handled entirely within the native environment and never 
surfaced to the X86 environment. The infrastructure allows all native interrupts, whether they 

20 ultimately go to the X86 environment or are absorbed in the native environment, to be 
recognized in any execution mode, whether the processor is currently converting X86 
instructions, emulating the X86, executing within the emulation routines themselves, or 
executing native instructions unrelated to the X86. Soft interrupt bits are used to transport the 
X86-surfaced hardware interrupts from the native environment to the X86 environment at an 

25 X86 instruction boimdary. Several instances of this will be discussed in sections IX.C.l, IX.C.2, 
IX.E.l,and IX.E.2. 



5. The frac bits, and continuing a recipe 

Referring again to Figs. 9a and 9b, as discussed in more detail in section IX.A.3, supra, 

30 the individual Tapestry instructions of a recipe are tagged with frac bits 930 to indicate the 
sequence number of the native instruction within the X86 recipe. Thus, even though the 
hardware operation of instructions is context-independent, frac bits 930 serve as a context stamp 
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to identify where in the recipe the instruction originated, to assist in estabhshing X86 context of 
a Tapestry native instruction. 

When an instruction raises an exception, typically in A-stage 144 through W-stage 150, 
exception tag 927 of the instruction is set to reflect the nature of the exception, and exception tag 

5 927 is recognized in W-stage 150. As part of initiating the exception, frac bits 930 for the 
excepting instruction are recorded into EPC.frac 934, along with the rest of the PSW/PC 
information that is recorded into EPC 914 (see Table 7 for a sample of error program counter and 
program status word information captured into this emulator interface register). Control is 
vectored to an exception handler; if the machine is executing in converter 136, most exceptions 

10 will be handled in emulator 316. (Exceptions to be surfaced to the X86 are initially handled by 
emulator 316, as discussed in section IX.A.2, supra) The exception handler completes by 
issuing an RFE (return from exception) instruction. 

To resume X86 execution, the RFE instruction reloads EPC processor register 914 into 
the operating IP, PSW and other state control logic of the machine. When the exception 

1 5 occurred during conversion of an X86 program, the EPC.ISA bit 194 will indicate the X86 ISA, 
as discussed in section II, supra. The EPC.EIP and EPC.frac 934 bits identify the X86 
instruction (by X86 instruction pointer) and the native instruction within the recipe, at which the 
exception was raised. The EPC.frac 934 value is restored into the T-stage frac register 931. The 
pipeline is flushed. The excepted X86 instruction is refetched by C-stage 902. T-stage 903 

20 retranslates the X86 instruction, but the recipe is not reissued to issue buffer 907 from its 

beginning. Rather, the recipe is reissued starting from the native instruction within the recipe 
indicated by the EPC.frac 934 value. Thus, neither the X86 instruction bytes, nor the 
intermediate pipeline state, need be saved in the hardware between the time emulator 316 is 
invoked and the return from emulation. 

25 

6. Expansion from external form to internal formatted form 

Referring to Figs. 9c and 9d, the expansion from the Tapestry native instruction form 

externally exposed, for instance to assembly language programmers, into an internal formatted 
form is a relatively trivial process of copying the explicit bits of the external native instruction 
30 (with some occasional modifications) into analogous fields of the internal formatted instructions, 
and supplying defaults for those fields that have no analog in the external native form. Some of 
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side-band information 940 is specific to load and store instructions, and is developed by 
converter 136 during the conversion 136 from X86 form to native formatted form. 

In the X86, memory addresses are not merely numbers between 0 and 2 -1 ; rather, the 
X86 uses "segment based addressing," in which addresses are of the form (segment, offset). 
5 Every memory reference, whether a load, a store, or an instruction fetch, uses such segment- 
based addressing. There are up to eight segments active at any point in time, including a code 
segment from which instructions are fetched, between one and six data segments from which 
memory operands are loaded and into which they are stored, and a stack segment into which 
PUSH instructions write their data, and from which POP instructions read their data. Thus, any 

10 instruction that explicitly specifies a segment contains a 3-bit immediate to specify one of the 
eight segment descriptors. The "offset" part of a memory reference is a number between 0 and 
2^^-l . Each segment has a maximum size; offsets into the segment that exceed the segment's 
limit are invalid. Further, each segment has a collection of permissions, controlling whether a 
program is allowed to read, write, or execute from the segment. Further, the segment has a D bit 

15 and a B bit that control the default size of memory references, and may have an "expand up" or 
"expand down" attribute. The attributes of each segment are cached in a segment descriptor. 
This is described in the Intel Architecture Software Developer's Manual, vol. 3, 
chapter 3, Intel Corp. (1997). 

In some X86 instructions, a designator for the segment descriptor off which a memory 

20 reference is based is explicitly coded as an immediate in the instruction. In other instructions, 
the segment reference is implicit in the opcode, rather than explicitly coded into the instruction. 
For instructions with an implicit segment reference, converter 136 develops an internal formatted 
load or store instruction with an explicit segment descriptor. 

For instance, some external native Tapestry load/store instructions specify a segment 

25 reference, addressing mode, and auto-increment, but no explicit displacement. For these 

instructions, the Tapestry native instruction decoder 132, 138 creates a formatted instruction by 
passing through the explicitly stated parts of the external instruction, and creating default values 
for the parts of the formatted instruction that have no analog in the external form. An example is 
the LDA/STA (load or store with auto-increment/decrement) external instruction 941 shown at 

30 the top of Fig. 9c. The fields of this instruction 941 are an opcode, a two-bit operand size, a six- 
bit specifier for a destination register (for LDA; for STA, the analogous field is the source 
register), a four-bit segment specifier and a six-bit specifier for an offset register, which together 
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specify a segment and offset for the memory reference, three bits to specify a pre- or post- 
increment or -decrement or no-modify mode, and four bits 942 to specify the address size and 
memory protection checks. The sixteen addressing modes generated by the four bits of address 



size/protection for LDA 941 are described in Table 10: 



Table 10 Addressing Modes for native Tapestry LDA instruction 




Description 


high three bits 
of mode value 


low order bit = Zero 


low-order bit = One 


000 


Load, 16-bit address 


Load check, 16-bit address 


Exception behavior: 
ReadFaults^ ^ ReadTraps^' ^ 


Exception behavior: 
ReadFauhs, STEP^ 


001 


Load with write intent, 16-bit address 


Load with write intent check, 16-bit 
address 


Exception behavior: 

ReadFaults, WriteFaults^, ReadTraps 


Exception behavior: 
ReadFaults, WriteFauhs, STEP 


010 


Load, 16/32 bit address based on 
SEG_CODE.B 


Load check, 16/32 bit address based on 
SEG_CODE.B 


Exception behavior: 
ReadFaults, ReadTraps 


Exception behavior: 
ReadFaults, STEP 


Oil 


Load and lock with write intent, 16-bit 
read/write-locked address 


Segment execute check, 16-bit 
addressing 


Exception behavior: 

ReadFaults, WriteFaults, ReadTraps 


Exception behavior: 
VECT_SEG_^ERROR.limit, STEP 


100 


Load, 32-bit address 


Load check, 32-bit address 


Exception behavior: 
ReadFaults, ReadTraps 


Exception behavior: 
ReadFaults, STEP 


101 


Load with write intent, 32-bit address 


Load with write intent check, 32-bit 
address 


Exception behavior: 

ReadFaults, WriteFaults, ReadTraps 


Exception behavior: 
ReadFauhs, WriteFauhs, STEP 


110 


Load with write intent, 16/32 bit address 
based on SEG_CODE.B 


Load with write intent check, 16/32 bit 
address based on SEG_CODE.B 


Exception behavior: 

ReadFaults, WriteFaults, ReadTraps 


Exception behavior: 
ReadFaults, WriteFauhs, STEP 


ill 


Load and lock with write intent, 32-bit 
read/write-locked address 


Segment execute check, 32-bit 
addressing 


Exception behavior: 

ReadFauhs, WriteFaults, ReadTraps 


Exception behavior: 
VECT_SEG_ERROR.limit, STEP 


^ ReadFaults = ReadWriteFaults + segment error on read, Taxi I/O (section VIII .A) 

^ ReadWriteFaults = segment error (user or limit error), alignment fault, TLB multiple hit, TLB miss, 

TLB protection 
^ ReadTraps = ReadWriteTraps + VGA read 

ReadWriteTraps = APIC, Tracepoint, Single-Step 
^ WriteFaults = ReadWriteFaults, segment error on write, TLB dirty, TAXi protected (section I.F) 
^ STEP = native single-step exception 
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In expanding an LDA/STA instruction 941 from the externally-exposed form to formatted form. 
Tapestry native instruction decoder (132, 138 of Fig» Ic) performs a very simple process of 
copying analogous fields, and filling in defaults for fields of the internal formatted form that are 
not explicitly set out in the external native instruction. For instance, because no load/store 
5 displacement is present in the external form 941 of the instruction, decoder 132, 138 supplies 
thirty-two explicit bits of Zero addressing displacement 924. The index register field is set to 
Zero to point to RO. The remainder of side-band information 920 is gathered from various places 
in the machine. 

As a second example, the LDB/STB instruction has an opcode field, a two-bit operand 

10 size, a six-bit specifier for a destination register (for LDB; for STB, the analogous field is the 
source register), a four-bit segment specifier and a six-bit specifier for an offset register, and a 
six-bit displacement, which together specify a segment and offset for the memory reference, and 
two bits to specify the address size and memory protection checks. The portions of the 
instruction that are specified explicitly are passed through, more or less unchanged. The six-bit 

1 5 displacement is sign-extended to thirty-two bits to create a displacement 924. 

Conversely, other instructions specify a memory offset, but no explicit segment 
descriptor. For these instructions, the Tapestry native instruction decoder 132, 138 creates a 
formatted instruction by, again, passing through the explicitly stated parts of the external 
instruction, and creating default values for other parts of the internal formatted instruction. For 

20 instance, the LDC/STC instruction has an opcode field, a two-bit operand-size field, a six-bit 
specifier for a destination register (for LDC; for STC, the analogous field is the source register), 
no segment specifier, and a six-bit specifier for an offset register, and a twelve-bit displacement, 
which together specify a segment and offset for the memory reference, and two bits to specify 
the address size and memory protection checks. The portions of the instruction that are specified 

25 explicitly are passed through, more or less unchanged. The six-bit displacement is sign-extended 
to thirty-two bits. Address size and memory protection check fields are generated automatically 
to reflect ordinary defaults, 

A fourth native Tapestry format, typically used for ADD and similar arithmetic 
instructions, is exemplified by instruction 943, at the bottom of Fig. 9c. Here, the right-most 

30 operand 944 of the instruction may either be a six-bit register specifier or a six-bit immediate. If 
the opcode specifies that field 944 is to be interpreted as an immediate, the six-bit value 944 is 
sign-extended to thirty-two bits into immediate field 924 of the formatted instruction. If the 
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opcode specifies that field 944 is to be interpreted as a register specifier, then the register value 
944 is copied to the second register source field 945 of the formatted instruction. 

In some embodiments, the four bit mode specifier 942 of an LDA/STA instruction, the 
two-bit address size and memory protection check field of an LDB/STB, and the two-bit address 
5 size and memory protection check field of an LDC/STC are each converted to a common form of 
at least four bits in the formatted instruction, so that all cases can be handled identically by the 
remainder 120 of the pipeline. In other embodiments, the instructions are passed through 
unmodified, and lower pipeline 120 uses the instruction opcode to decode the remainder of the 
instruction. 

10 The operation of the side-band information 920, 940 need not be entirely orthogonal to 

the native instruction opcode. For instance, in some instructions in some embodiments, the 
immediate field 924 of the side-band may be treated as an arithmetic immediate value, in others 
as a load or store displacement, in others, a segment-relative absolute branch displacement or 
PC-relative branch displacement, and in others (for instance, some addressing modes of 

15 load/store), the thirty-two bits of immediate in the formatted instruction are ignored. In some 
instructions, only eight or sixteen bits of one of the immediate or displacement field 924 are 
used, and the high-order bits and the bits of the other field are ignored. 

Converter 136 converts X86 instructions into Tapestry instructions in formatted internal 
form. For the most part, the formatted instructions emitted by converter 136 are identical to 

20 formatted instructions generated from external Tapestry instructions by Tapestry instruction 

decoder 132, 138. The few exceptions include values for immediates and displacements that can 
be coded in the large immediate fields of the X86 instruction but cannot be coded in the smaller 
immediate fields of Tapestry external form, certain processor register accesses (e.g. for profile 
collection, as discussed in Section V.F), and certain other examples mentioned elsewhere in this 

25 disclosure. 

B, Individual retirement of instructions 

A number of different techniques are used to render instructions independent of each 
30 other. As a result, when a native instruction faults, either the fault can be serviced and the X86 
instruction can be restarted from the faulting native instruction, or execution can be terminated. 
All side-effects will either be committed to X86 architected state co-atomically, or none will be 
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committed. Little special-purpose hardware is required to capture intermediate results of an X86 
instruction and preserve those results for restart. Unwinding of partially-committed X86 
instructions is seldom required. Converter 136 tenders execution to the X86 environment in an 
architecturally-consistent state, at an instruction or interrupt boundary. 

5 

1. Recipe use of temporary registers 

Recall from Table 1 that some of the registers of the Tapestry native machine are mapped 

to specific resources of the X86 (e.g., R32-R47 to the floating-point registers, R48-R55 to the 
integer registers), some are assigned to Tapestry-specific uses while converter 136 is active (RO 

10 is read-only always zero, R1-R3 reserved for exception handlers, R4 is an assembler temporary 
for use as the assembler sees fit, R15-R31 assigned to use by profiler 400), and some are 
unassigned (e.g., R56-R63). 

Among the registers assigned to specific purposes are R5-R14, designated in Table 1 as 
"CTl" through "CTIO," for "converter temporary." These registers hold the intermediate results 

15 of X86 instructions (for instance, addresses formed from complex addressing modes, or memory 
operands) and carry these intermediate results from one native Tapestry instruction to another. 
The converter uses these registers only to carry values within an X86 instruction, not from one 
X86 instruction to the next. Thus, on a trap or other context switch that occurs on an X86 
instruction boiondary, it is knovra that all of the valid X86 state is in registers R32-55, and state in 

20 registers R5-14 and R56-63 can be abandoned. Also, it is known that the temporary values in 
R5-R14 will not collide with any other use. But because this machine state is in ordinary 
registers, ordinary state saving techniques serve to save these intermediate results. This 
contrasts, for instance, with the special mechanisms that the X86 itself must use to save 
intermediate instruction results on the memory stack, because the intermediate results are not 

25 stored in the architecturally defined machine resources of the X86. 

Referring to Fig, 9e, temporary registers are used in recipes where the X86 architectural 
definition calls for state that changes progressively through a single instruction. One example of 
the use of a temporary register is the recipe for the X86 PUSHAD instruction (push all general- 
purpose registers to the stack). The left portion 950 of the figure shows the operation of the 

30 instruction, as shown in the Intel Architecture Software Developer's Manual, vol. 2, 
page 3-388. The right portion of the figure shows the native Tapestry recipe that implements 
those operations. 
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The STOREDEC instruction 951 is a particular variant of the Tapestry STA (store with 
auto-increment/decrement) instruction (see discussion of STA in section IX.A.6). The ".X" 
opcode extension can be 16 bits or 32 bits, to indicate the size of the second operand. The first 
operand 952, interpreted according to the opcode extension, is stored to memory, at the address 
5 indicated by the second and third operand. The second operand is a segment descriptor. The 
third operand 953 is a register containing the offset into the segment. The third operand's 
register is pre-decremented by the size of opcode extension, before the first operand 952 is 
actually stored. 

The first MOVE instruction 954 of native recipe 950 copies the X86 stack pointer ESP 
1 0 into a temporary register tmp_d, which is one of the CTI-CTIO registers, R5-R14 of Table 1 . 
The eight STOREDEC instructions 951 push the eight general purpose registers EAX, ECX, 
EDX, EBX, ESP, EBP, ESI and ECI onto the stack. During these pushes, the actual X86 stack 
pointer in register ESP remains unahered; the decrementing is performed on register tmp_d. 
Finally, in the final instruction 955 of the recipe, register tmp d is copied to the X86 stack 
15 pointer ESP. 

Recall from sections IX.A.2 and IX.A.4 that, unlike a conventional machine, exceptions 
during X86 conversion or emulation do not build stack frames in memory (unless emulator 316 
determines to surface the exception to X86 operating system 306); rather, the requisite machine 
state is exposed in emulator interface registers 912 and EPC 914. The execution of converter 

20 136 and emulator 316, including entry to and exit from emulator 316, have no side-effects on any 
X86 architecturally- visible state, except the state change defined by the X86 architecture. Thus, 
any asynchronous interrupts that occur during the PUSHA converter recipe are handled in 
Tapestry operating system 312 or in emulator 316, with no side-effects made visible to the X86. 
Note that "handling" an interrupt in emulator 316 may consist of recording that it is pending, 

25 returning to converter 136 to complete the current X86 recipe, and then accepting the interrupt 
and surfacing it to the X86 when the X86 instruction is complete 926 - note that the interrupt 
only is visible to the X86 at an instruction boundary (other examples of this behavior are 
discussed in section IX.E.2). 

Synchronous exceptions during instruction execution are sometimes signaled in the 

30 middle of a recipe. In the case of PUSHA, on a mid-instruction synchronous exception, the X86 
architecture defines that memory is partially modified, but the stack pointer is unmodified. 
Recipe 950 achieves this behavior - on a synchronous exception during recipe 950, the stack 
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pointer register, which is architecturally visible to the X86, remains unchanged until the final 

MOV instruction 955. The register that carries the intermediate decrementing of the stack 

pointer, tmp_d, is invisible in the X86. 

Because no state visible to the X86 is altered until the final MOVE instruction 955, if 
5 recipe 950 is interrupted at any point, the recipe can be restarted from the point of the exception. 

The X86 environment Will only see the state at precise instruction boundaries. 

Fig. 9f gives a representative catalog of the recipes that use temporary registers. As a 

general rule, temporaries are used in recipes where there is more than one change to X86 

architected state, for instance, for instance, where there are multiple changes to a single register 
10 (the implicit stack pointer in the PUSHA example of Fig. 9e), or changes to more than one 

register. 

In one example, the X86 definition requires that the destination register of a floating- 
point operation be left unmodified in certain cases of IEEE-754 non-numeric data (IEEE-754 
NaN's, infinities, etc.). Because Tapestry implements the Intel 80-bit floating-point registers in 

15 two pieces (a 16 bit sign and exponent, registers R33, R35, R37 . . . R47 (see Table 1) and a 64- 
bit significand in registers R32, R34, R36 . . . R46), some loads and stores are decomposed into 
two operations, and IEEE-754 checks cannot be performed until all bits are collected. The two 
portions of the floating-point value are loaded into a pair of temporary registers. The IEEE-754 
checks can be performed in the temporaries. Once the two parts of the datum have been 

20 validated, the floating-point value is copied into the final destination registers that are part of the 
X86 state. 

In another example, the integer condition codes during repeated string instructions are 
saved in a temporary register to preserve them across a page fault, and reloaded from that 
register when execution is resumed from a page fault. 
25 In each case, the intermediate resuhs are held in temporary registers until all possibilities 

for exceptions have been evaluated. The data are committed to X86-visible resources only when 
all operations can be guaranteed to complete. This allows recipes to be continued from the point 
of any exception, without having to record state from younger instructions that have already been 
retired. 

30 
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2. Memory reference instructions that trigger protection checks suited 
for a different reference class 

Referring to Fig. 9g, the X86 instruction set allows a single instruction 960 to both read 

and write the same memory location, for instance "ADD memory, register" (the two addends are 
5 a memory location and a register; the sum is stored back into the memory location). Such 
instructions are called "read-modify-write" instructions. The X86 architecture definition 
requires that the read of the read-modify- write will only issue off chip from the X86 CPU to the 
system bus and the memory system if the write will also be successful. This constraint reflects 
the possibility that the memory location is in I/O space, where the read may change the state of a 

10 device, and must not be issued more than once. 

Referring to Figs. 9c and 9g and Table 10 of section IX.A.6, the Tapestry instruction set 
includes an instruction that accomplishes three results: (a) performs memory checks to ensure 
that a read from the effective address will complete, (b) performs memory protection checks to 
ensure that a write to the same address will complete, and (c) loads an operand from memory to a 

15 register. Such a load is called a "write intent" load. The load fails if either the load checks fail 
or the store checks fail. Note in Table 10 that addressing modes 942 0010, 0011, 01 10, 1010, 
1011, 1 100, 1 101, and 1 110 of LDA indicate loads with write intent. Addressing modes 01 1 1 
and 1111 indicate loads with execute intent. 

The opcode and addressing mode 942 of the instruction specify a memory protection 

20 predicate to be evaluated by the instruction. For instance, the memory protection predicate for a 
"write intent" load embodies a query whether the segment of the effective address may be read 
as data and written as data, and that the effective address is within the segment limit. Other 
predicates for other loads may embody a query whether the segment of the effective address may 
be read as data and read for an instruction fetch (with a segment limit check), or that omits the 

25 load operation and only performs the memory protection and segment limit checks (as will be 
further discussed in section IX.B.3.b), etc. 

The memory protection predicate is evaluated over the protection bits of the TLB entry 
for the effective address (in base and offset form) of the load or store (the segment protection bits 
are cached from the segment descriptor and address translation page tables into the TLB). 

30 Thus, the first instruction in recipe 961 for an X86 read-modify-write ADD 960 is a 

Tapestry LDA instruction 962. As discussed in section IX.A.6 in connection with Fig. 9c, the 
LDA instruction 941 has explicit specifiers for an addressing mode 942, the segment, and an 
offset register. As LDA instruction 962 is generated by TIG's iO 905 and il 906, addressing 
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mode bits 942 are set to indicate that LDA 962 is a write intent load. The second instruction in 
recipe 961 is an ADD instruction 963, which performs the addition itself. The third instruction 
in the recipe is an STA (a store to an X86 address) 964, storing to the same address as the 
address referenced by the LDA 962. The STA 964 repeats the address calculation that was 
5 already performed by LDA 962, and also repeats the same store permission checks. The 

permission checks are guaranteed to succeed without an exception because the same checks were 
already specified by mode bits 942 of LDA 962. Thus, in recipe 961, only LDA 962 can raise an 
exception - ADD 963 and STA 964 are guaranteed to complete. 



1 0 3, Target limit check instruction 

When the X86 architectural definition requires simultaneous modifications/side-effects, 

the Tapestry implementation checks the validity of the modifications/side-effects, and uses temps 
to hold intermediate results, to ensure complete execution before any architected state is 
modified. 

15 Recall fi-om the brief overview of the X86 segmentation scheme, introduced in section 

IX.A.6, that each X86 segment has a maximum size; offsets into the segment that exceed the 
segment's limit are invalid. Thus, on each load, store, or instruction fetch memory reference, the 
offset of the reference is compared to the limit for the appropriate segment. 

Limit checking is context dependent. The following subsections discuss a representative 

20 sample of limit checks that are performed for loads, stores, instruction fetches, and control flow 
transfers. 



a. LOAD/STORE and branch limit checks 

Referring again to Fig. 9a, limit checks are performed at two points in the hardware. For 

25 sequential instruction flow and some control transfer instructions, the limit check for the transfer 
destination is performed in upper portion 134 of the pipeline. For other memory references, the 
limit check is performed in M-stage 146 where the memory reference itself is performed. 

The upper limit check is performed for those control transfers for which the destination 
address can be computed based entirely on information available during instruction decode, after 

30 the X86 instruction boundaries have been identified. This class includes straight sequential flow 
and IP-relative branches. The three pieces of information required for the limit check include the 
IP of the current instruction, the length of the current instruction, and the branch displacement of 
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the instruction. These three are available in T-stage 903, and before issue buffer 907. Once this 
information is known, the three components of the branch destination can be summed, and 
compared to the segment limit in the segment descriptor for the X86 code segment. 

The lower limit check is in M-stage 146, Much of address formation may have been 

5 performed by distinct single-operation RISC instructions earlier in the recipe. The final load, 
store or jump will form a target address by summing a segment base from a segment descriptor, 
and an offset, which may itself be formed as the sum of an immediate displacement and one or 
two registers. The address is formed in the ALU of A-stage 144, the ALU used in ordinary 
addition instructions. After address formation, and in parallel with the cache access in M-stage 

10 146, the offset is compared to the segment limit for the segment designated by the Tapestry 
instruction. 

The X86 defines the following behavior for limit check exceptions. In a load/store 
reference, the entire reference must fit within the segment limit, and thus both the address of the 
lowest byte and the address of the highest byte of the reference play a part in the limit check. In 

15 a control transfer, only the first byte of the destination need be within the code segment, so only 
a single address of destination address is tested against the limit. For instance, if the first 
instruction of a branch target is two bytes long and only the lower byte is within the limit, then 
the control transfer itself completes normally, and an exception will be delivered on the 
instruction fetch at the target, not at the control transfer itself. If the first byte of the target is not 

20 within the limit, then the control transfer faults, and the instruction does not execute at all For 
instance, for a CALL instruction to a target whose first byte is outside the limit, the return 
address is not written to memory, the stack pointer is not modified, and the exception IP points to 
the CALL instruction, not to the target. On the other hand, if the first byte is within the limit but 
the second is not, then the retum address is pushed to memory, and the destination instruction 

25 takes a page fault or segment fault. 

Limit checks in T-stage 903 and M-stage 146 differ for loads/stores and control transfers, 
to implement the behavior defined in the X86 architecture. Several examples follow. 



b. Target limit check for near register-relative CALL 

30 Referring to Fig, 9h, because much of the semantics of load and store instructions are 

explicitly exposed in the native and formatted instruction encoding, rather than being inferred 
from the opcode, a load can be defined that performs a segment limit check only, with no check 
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for execute mode access and no actual load of the datum. This load operation is useful as a 
segment check for a near transfer - because a near transfer is within the same segment 
containing the current instruction, it is known that the segment is executable and thus this check 
can be omitted). Such a load instruction can be used to implement the limit check on a near 
5 branch destination (that is, a branch destination in the same segment) of a register-indirect form 
of the X86 CALL instruction. This implementation reports a segment limit fault early enough 
to prevent modification of any architecturally-visible state, thus reducing the amount of work 
that must be performed to back out a partially-completed X86 CALL instruction. 

The left portion 967 of Fig. 9h shows an excerpt from the operation description of the 

10 CALL instruction shown in the INTEL ARCHITECTURE SOFTWARE DEVELOPER'S Manual, vol. 
2, page 3-41, commencing at a point after the target address has been formed. The X86 CALL 
instruction first checks 968 whether the first byte of the branch target is within the code segment 
limit, and if not, signals a general protection fault. The CALL instruction then checks 969 
whether the memory stack has room to accept a push of the return address. Even though the 

15 stack check is also a limit check, failure is indicated by a stack fault, not a general protection 
fault. Only if both checks succeed, then the current offset into the code segment (EIP) is pushed 
onto the stack, and then control is transferred to the destination. 

The right side 970 of Fig. 9h shows the portion of the converter's recipe corresponding to 
the segment in the left portion. Excerpt 970 assumes that the target address is already in register 

20 reg d, either because the X86 CALL is to a register address, or because an earlier address 
formation excerpt of recipe 970 has formed the target offset into temporary register reg_d. 
Instruction 971 

LOAD.limit_check rO, CS:reg_d 
performs the first limit check 968 of the left side, comparing the target address against the code 

25 segment limit. The destination of load 971 is RO, the always-zero register; thus only the 

protection checks are performed and the actual memory load is simply omitted; this prevents 
spurious interlocks. The 'Mimit_check" specifies that the memory management hardware is to 
be queried for both data load and instruction fetch protection checks (or, in another embodiment, 
instruction fetch instead of data load checks), as specified by addressing mode bits 942 of an 

30 LDA instruction, as discussed in section IX.B.2, supra. The address to check is in the code 

segment, at offset in reg_d. If LOAD.limit_check 971 fails, then the remainder of recipe 970 is 
suppressed, and the CALL return address will not be stored by STOREDEC 972. The second 
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instruction 972, STOREDEC, is a pre-decrementing store that pushes the IP value onto the stack 
segment (SS) at the offset specified by the stack pointer ESP. As the memory write of 
STOREDEC 972 begins, it is known that both segment checks (check 968 of the branch 
destination against the code segment Umit and check 969 of the stack segment) will succeed - 
5 the branch destination was tested by the LOAD.limit_check instruction 971, and the stack 

segment is tested by the STOREDEC 972 itself. Thus, at the conclusion of STOREDEC 972, it 
is known that all three side-effects (the memory write, the change to the stack pointer, and the 
change to the IP) will succeed, and the architecturally-visible side-effect of storing the CALL 
return address can be committed to memory. The JR instruction 973 jumps to the address 

10 specified by reg_d. Because, in the general case, the destination register of a JR could be 

computed by the immediately-preceding instruction, the contents of a jump destination register 
(reg_d in this case) cannot be limit checked in the limit check hardware of T-stage 903. Thus, a 
JR instruction is one of the jump instructions that performs its segment limit check in M-stage 
146, However, because recipe 970 has already performed a LOAD.limit_check 971 on this 

1 5 destination, JR 973 is guaranteed to succeed. 

4, Special grouping of instructions to ensure co-atomic execution. 

The X86 IP-relative near CALL 976 is described in the left hand side of Fig. 9i. The call 

target offset is computed as the sum of the instruction location itself, the instruction length, and 
20 the displacement immediate in the instruction. The address of the following instruction is 

pushed on the stack, and control is transferred to the call target. The Tapestry implementation 

ensures that either both parts of the instruction complete, or neither. 

In one embodiment, the X86 IP-relative near CALL 976 is handled analogously to the 

recipe 970 described in section IX.B.S.b, supra, A LOAD.limit_check instruction (analogous to 
25 instruction 971) limit checks the call target - the current IP is added to the length and 

displacement of the instruction, and this sum is compared against the code segment limit. 

Failure of this LOAD.limit_check aborts the remainder of the recipe. Then (on success), a 

STOREDEC instruction (analogous to instruction to 972) pushes the return address. A jump 

instruction jumps to the target. 
30 Referring to Fig, 9i, in another embodiment, the recipe for an X86 IP-relative near CALL 

976 includes a STOREDEC (a pre-decrementing STORE of the IP value) 977 and a jump 

instruction 978. The hardware monitors these two distinct instructions 977, 978 to ensure that 
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they complete together. Because all of the information needed to compute the call target offset 
(the instruction location itself, the instruction length, and the displacement immediate in the 
instruction) is available in upper part 134 of the pipeline, it is possible to do the target limit 
check in the T-stage 903 limit check circuitry. This limit check can be performed without 

5 stalling, concurrently with the instruction generation, because all of the information required to 
form the target address is available as the instruction is decoded. Branch target hardware is 
provided in upper portion 134 of the pipeline so that most IP-relative branches can compute their 
branch targets and limit check them early in the pipeline, and this circuitry is readily available 
for use in IP-relative CALL 976 instructions to compute the call target and to compare that call 

10 target to the code segment limit. This allows the IP-relative near CALL 976 to be coded in two 
Tapestry instructions 977, 978, instead of the three instructions generated for the register- 
destination CALL discussed in section IX.B.S.b. STOREDEC 977 and jump 978 are held in the 
issue mechanism until the call target limit check is completed. If the call target limit check fails, 
then STOREDEC 977 and jump 978 are both nullified, preventing the modification to memory. 

1 5 If the CALL target limit check succeeds, then both instructions are released. If STOREDEC 977 
fails, the entire X86 instruction will be aborted. Once STOREDEC 977 completes, jump 978 is 
guaranteed to succeed because of the limit check performed in T-stage 903. 
The feature is implemented as follows. 

The upper portion stages 134 guarantee that the segment limit of the target of jump 978 is 
20 checked before STOREDEC 977 is issued. After STOREDEC 977 clears C-stage 902, C-stage 
902 uses the displacement of jump 978 to compute the target address. T-stage 903 performs the 
limit check for the target. The success or failure of the limit check is tagged onto STOREDEC 
977 which is just ahead in upper pipeline 134. This tag is staged down the pipeline with 
STOREDEC 977 as it moves into D-stage 140 and lower pipeline 120. If the jump target limit 
25 check fails, STOREDEC 977 is marked with a fault before it is issued into the execution pipeline 
120. 

In another embodiment, as instructions are decoded, an IP-relative near CALL is caught 
as a special case. The TIG's 905, 906 mark STOREDEC 977 with a special marker. An 
instruction with that marker is not allowed to move from the upper portion 134 into execution 
30 pipes 120 (or in another embodiment, is held in issue buffer 907) until the target formation and 
limit check is completed for jump 978. The pipeline is arranged so that this check is performed 
early enough so that STOREDEC 977 is usually released from issue buffer 907 without a bubble. 
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The marker is somewhat analogous to the side-band information 920 that propagates through 
lower pipeline 120, except that it is only used within the upper stages 134. 

In another embodiment of IP-relative or register CALL instructions 967, 976, T-stage 903 
or M-stage 146 checks for a limit error on the target of the jump instruction 973, 978. If there is 
a limit error, a limit exception is tagged onto STOREDEC 972, 977. The exception on 
STOREDEC 972, 977 is recognized in due course in W-stage 150, and STOREDEC 972, 977 
never commits to memory. The abort of STOREDEC 972, 977 aborts jump 973, 978 in turn. 
The limit check on jump 973, 978 completes and is available in time to reach forward in pipeline 
120 to tag an exception onto STOREDEC 972, 977 before STOREDEC 972, 977 commits in W- 
stage 150, either because the two stages are far enough apart, or because STOREDEC 972, 977 
is delayed in committing (as an exception to the general design goal of independent retirement of 
instructions) until the limit check succeeds. 

5. Far calls 

Tapestry implements far calls in emulator 316. The limit check for the target address is 
performed using a load-with-execute-intent instruction analogous to the load-with-write-intent 
instruction discussed in section IX.B.2, supra. This single instruction accomplishes work that 
would otherwise require extracting the target segment limit from a segment descriptor and 
comparing that segment limit against the target offset. 

6. Unwind in the emulator of LOOP instruction 

Referring to Fig. 9j, the X86 architecture defines a complex LOOP instruction. The left 
half 980 of Fig. 9j shows the operations for one of the simpler variants. Before entering a loop, 
the program establishes a loop count in the ECX register. The LOOP instruction is used at the 
end of the loop body. The LOOP instruction decrements the ECX register on each iteration of 
the loop. As long as the ECX register is non-zero, the LOOP instruction transfers control back to 
the instruction at the top of the loop, to initiate the next iteration of the loop. 

The native Tapestry recipe 981 for this variant of the LOOP instruction generates two 
instructions, a DEC decrement instruction 982 and a CJNE 983 (conditional jump if not equal to 
zero) based on the resuh of the DEC 982. DEC instruction 982 may have an operand that is 
eight, sixteen, or thirty-two bits wide, indicated by the ".X" opcode extension. CJNE instruction 
983 compares the ECX register to rO (the always-zero register, see Table 1), and branches if they 
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are not equal The "immS" argument to the LOOP 980 or CJNE instruction 983 is a 
displacement, which may be eight, sixteen, or thirty-two bits in the X86 LOOP instruction, 
widened to 32 bits in the formatted CJNE native instruction 983 emitted by converter 136. 

Like any other control transfer target, the target of a LOOP instruction 980 must be limit 

5 checked against the code segment limit. In the X86, the limit check is performed, then ECX is 
modified, and then the branch occurs. If the limit check fails, then the modification of ECX is 
not committed. However, in recipe 981, DEC instruction 982 comes before the branch 983, and 
because of the frequency of LOOP instructions, it is desirable to keep the recipe 981 at two 
instructions instead of adding a third simply to do the limit check. 

10 In one embodiment, the CJNE instruction 983 is marked with the limit check failure, and 

is also side-band marked as an instruction in a LOOP recipe. When CJNE 983 reaches W-stage 
150, the hardware recognizes the segment limit error and stores the LOOP side-band info into the 
memory fault code. The segment limit error handler, in turn, examines the memory fault code. 
If X86 LOOP bit (bit 25 of the "memory fault code" processor register) is set then ECX (or CX) 

15 is unwound one step 

In another embodiment, the X86 LOOP instruction is one of the few instances in which a 
later instruction (CJNE 983) is allowed to influence the execution of an earlier instruction (DEC 
982). The CJNE instruction 983 is limit-checked in T-stage 903. The result of this limit check is 
tagged onto the CJNE instruction in side-band information 920 as a one-bit tag named "X86 

20 LOOP." The X86 LOOP tag is staged down the pipe with the other side-band information 920 
for CJNE instruction 983. When W-stage 150 detects an instruction with an X86 LOOP tag 
indicating that the limit check failed, the processor traps into emulator 316, and emulator 316 
increments register ECX (or register CX, for word width) by one, to unwind the decrement by 
the last DEC 982. 

25 

7. Repeated string instructions 

Referring to Fig, 9k, the X86 architecture defines a REP prefix byte to certain 

instructions to derive a set of "REP" repeat instructions, for instance "REPE CMPS" (repeat the 
"compare byte" instruction to derive "compare string"), "REP MOVS" (repeat the "move byte" 
30 instruction to derive "move string"), and "REP SCA" (scan string). In each of these repeated 
string instructions, the X86 repeats a more-basic operation for a number of repetitions. The 
repetition count is specified in one of the general purpose registers, register ECX (32-bit mode) 
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or CX (16-bit mode). In the example 986 shown in Fig. 9k, "REPNZ MOVS " the X86 uses 
register ECX as a count register, and moves bytes from a source memory operand to a 
destination memory operand. At each repetition, the X86 accepts any pending interrupts, then 
decrements ECX and performs the associated MOVS instruction. The repeat instruction is not 

5 itself a branch instruction; rather it is a one-byte prefix on another instruction that instructs the 
X86 to repeat execution of that instruction until an exit condition is met, and then fall through to 
the next sequential instruction. 

When X86 instruction decoder 136, 929 encounters a repeated string instruction, decoder 
136, 929 may not yet know what the repeat count value is - the value may not yet be computed, 

10 or may still be flowing down the pipeline and not yet committed to register ECX/CX. T-stage 
903 issues an apparently-infinite sequence of instructions to process each iteration of the string 
and those iteration values are marked off by a branch instruction 989. The inter-iteration branch 
instruction 989 is a regular branch instruction that's accessible to the native programmer, rather 
than a special purpose branch instruction just for the string instruction. 

15 T-stage 903 renders a REP instruction as an infinitely-imroUed loop of straight-line 

instructions 987, instructions 988 that encode each iteration of the string operation, separated by 
inter-iteration branch instructions 989. Near the beginning of the recipe (before the excerpt 
shown in Fig. 9k) is a branch instruction that branches to the next X86 instruction if the repeat 
count in ECX is Zero. Then follows the native instructions for the first iteration 988 of the loop. 

20 In the case of REPNZ MOVS, the body 988 of the loop is a load, a store, and a JNZ instruction 
that is predicted not taken. This portion 988 will vary to reflect the X86 instruction that is being 
repeated. 

At the end of the each iteration 988, T-stage 903 emits a jump instruction 989, predicted 
not taken, to the following X86 instruction. These inter-iteration branch instructions 989 are 

25 each marked with the "interruptible iteration boundary" side-band marker (990 of Fig. 9c). 
Paralleling the behavior of the X86, the inter-iteration branch instruction 989 tests temporary 
flags that reflect the countdown of ECX. These temporary flags are parallel to but distinct firom 
the X86 EFLAGS, so that the EFLAGS themselves are not modified. 

When inter-iteration branch 989 reaches R-stage 142 and A-stage 144 (where branches 

30 are actually executed), if the ECX count is not exhausted, branch 989 is not taken, in accord with 
its prediction. The recipe for the repeated string instruction continues with the next iteration 
body 991. On the other hand, if the repeat count is exhausted, then the branch condition is 
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satisfied, and the branch mis-predict circuitry is activated to flush pipeline 120. Top portion 134 
stops generating iterations of the repeated instruction. In one embodiment, the completion of the 
instruction is based on the exhaustion of the repeat count. In another embodiment, completion is 
based on the recognition of the mis-prediction. The recognition of the mis-predict, taken 
5 together with the fact that T-stage 903 is decoding a string instruction, causes the pipeline to 
flush the unused instructions for excess iterations that were generated by T-stage 903, and to 
move X86 instruction decoder 136, 929 forward to the next instruction. Execution resumes with 
the following X86 instruction. 

Each inter-iteration branch 989 is marked with end-of-recipe marker X86_COMPLETED 

10 926, so that when the instruction finally does terminate, all the proper state will be updated - for 
instance, the IP will be incremented, etc. However, the iteration boundary marker 990, which is 
also asserted on the same branch instruction 989, partially overrides the end-of-recipe marker 
926, signaling to the W-stage hardware that the end-of-recipe mark 926 is conditional, that the 
end-of-recipe processing should only be performed when the iteration count is exhausted. 

15 In X86 single-step mode, each iteration of a repeated instruction triggers an X86 single- 

step exception. When both X86 single-step and Tapestry native single-step mode are enabled, 
the interaction between the two is resolved in emulator 316. 

C. Collecting results of multiple native instructions to emulate multiple side- 
20 effects of a single X86 instruction 

1. Load/store address debug comparison result gathering and filtering 

The X86 architecture defines a debug feature. There are four debug registers, each of 

which can hold a linear address. Each register specifies a length of one, two, or four bytes; the 
address must be naturally-aligned to the length. Each register can also be tagged with a class of 

25 memory reference: read, write, or execute. On each memory reference, the address of the 
reference is compared against the addresses and modes in the four debug registers. When a 
memory reference falls within the range between the debug address and (address + length), and 
the reference mode matches the class tag of the register, a trap is raised at the end of the X86 
instruction, and the address of the reference is made available to debugger software. Since an 

30 X86 instruction may have multiple memory references, it is possible to have several matches in a 
single X86 instruction. 
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Tapestry provides an analogous featiire, "tracepoint" registers. Each Tapestry tracepoint 
register holds an address to be monitored. The tracepoint address matching granularity is 
somewhat coarse, to the granularity of a 16-byte cache line, rather than to a single byte, two 
bytes or four bytes as in the X86 debug hardware. The Tapestry processor takes a native 
5 exception at the end of each memory reference that hits in a cache line whose address is in a 
tracepoint register. The Tapestry tracepoint registers do not perform the match against memory 
read/write reference class. Rather, the finer granularity address matching and reference class 
matching are performed in emulator 316. When a memory reference is detected whose address 
falls within the cache line of one of the tracepoint registers, the processor traps into emulator 

10 316. Emulator 316 gathers more information from emulator interface processor registers 912, to 
determine whether the address matched to the granularity required by the X86 architecture 
definition (to the nearest one, two or four bytes, depending on the operand width), and to 
determine whether the class of the actual memory reference matches the software-managed 
record of the class to monitor. If emulator 316 discovers that the address of the memory 

15 reference does not overlap the address range specified to be monitored (between the X86 debug 
register address and that address plus the length), then emulator 316 takes no action and 
immediately returns to converter 136. Emulator 316 also determines whether the matching 
reference was a load or store, and compares that determination to the class of memory references 
that are to be monitored for the address in this register. If there is no match, emulator 316 

20 returns to converter 136. If the address match survives the granularity and memory-reference- 
class filtering, emulator 316 marks a bit in a bit vector, where the bit vector has a bit 
corresponding to each X86 debug register, and turns on X86 single-step mode. (The X86 
architecture defines a single-step mode in which execution is trapped at the end of each 
instruction, so that a debugger can be invoked. This is implemented in Tapestry as a trap that is 

25 raised as each instruction with an X86_COMPLETED end-of-recipe tag 926 is executed while 
the processor is in single-step mode. The use of single-stepping here is analogous to that 
discussed in sections IX.C.2, IX.B.6, and IX.B.7.) The handler then RFE's back to converter 
136 to continue the recipe. At the end of the X86 instruction, a single-step trap will be raised by 
converter 136, and control will vector into emulator 316. If emulator 316 discovers that the bit 

30 vector has any bits set, indicating that there were one or multiple tracepoint register matches 
raised in the single instruction, emulator 316 surfaces the X86 breakpoints to the X86 
environment as appropriate. At the conclusion of emulator 316, single-stepping is timied off 
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(unless single-stepping was turned on in the virtual X86, rather than by emulator 316 for a single 
instruction). 

Consider the example of the PUSHA instruction, that pushes all six general registers onto 
the stack. If several of the X86's four debug registers all point to nearly-adjacent locations in the 

5 stack, a single PUSHA instruction could trigger multiple matches of debug registers. Each 
match raises a Tapestry tracepoint exception, and the tracepoint handler marks a bit in the bit 
vector to indicate which tracepoint register matched. At end 926 of the PUSHA instruction, an 
X86 single-step exception transfers control to the single-step handler, which detects the bits set 
by the tracepoint handler. Instead of RFE'ing back to the next instruction in converter 136, the 

1 0 single-step handler vectors to the X86 operating system entry point for debug exceptions. 

Thus, load and store debug addresses are collected on the basis of individual Tapestry 
instructions, and surfaced to the X86 on the basis of complete X86 instructions. 

2. FP-DP/IP/OP postponement 

15 Referring again to Fig. 9a, FP DP/IP/OP circuitry 993 stages the floating-point data 

pointer, instruction pointer, and opcode information dovm the pipeline. 

The X86 floating-point unit (FPU) stores pointers to the instruction and data operand for 
the last non-control floating-point (FP) instruction ("control instruction" is a defined term in the 
Intel X86 architecture) in two 48-bit registers, the FPU instruction pointer (FP-IP) and FPU 

20 operand (data) pointer (FP-DP) registers. (The X86 architecture defines FP-DP information only 
for single-memory-operand instructions; memory-to-memory operations are non-control 
instructions, so there is no need for multiple DP pointers.) The X86 FPU also stores the opcode 
of the last non-control instruction in an eleven-bit FPU opcode register (FP-OP). This 
information is saved to provide state information for exception handlers. The instruction and 

25 data pointers and the opcode information are accessed by executing the X86 instructions 

FNSTENV and/or FNSAVE, which store the information to memory in a format dependent on 
the current X86 mode. 

Tapestry models this aspect of the X86. 

As an X86 floating-point instruction is converted to native instructions in T-stage 903, FP 
30 side-band information is generated and staged down the pipeline. This FP side-band information 
indicates that this is a floating-point instruction, and includes a snapshot of the IP value (FP-IP) 
and opcode value (FP-OP). The FP-IP and FP-OP values are passed firom the converter to pipe 
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control 910, which in turn stages the information from D-stage to W-stage 150. The data pointer 
FP-DP, the memory reference address, is developed in A-stage 144. The FP-IP, FP-OP and FP- 
DP information, and exception information, stages down through pipe control 910 to FP- 
IP/OP/DP logic 993 in W-stage 150. This side-band information is staged down pipeline 120 in 

5 a mode-independent canonical format for formatted instructions, as shown in Fig. 9c. 

FP-IP/OP/DP logic 993 includes "sticky" registers 994 that accumulate information over 
the native instructions relating to a single X86 instruction. For instance, if the memory reference 
of the computation is in the first instruction in recipe, and the arithmetic operation is the last 
native Tapestry instruction of the recipe, then the memory reference information that will 

10 ultimately be saved in FP-DP flows down the pipeline control logic with the memory reference 
Tapestry instruction. The FP-IP/OP/DP side-band information from all instructions of a single 
X86 instruction's recipe is accumulated in the FP-IP/OP/DP sticky registers 994. 

The FP-IP/OP/DP information is maintained in an internal format that is somewhat 
different than the X86 format. The information may be generated by two or more different 

15 instructions in the recipe. The Tapestry internal format is retained during native instruction 
processing. 

The FNSTENV and FNSAVE instructions are executed in emulator 316 rather than 
hardware converter 136. 

In some embodiments, when an X86 instruction requests access to the FP-IP/OP/DP 

20 information (e.g., FNSTENV, FNSAVE, Entry to SMM), emulator 316 may translate the 

canonical form of the pointers as stored by the Tapestry hardware (a 16-bit segment selector and 
a 32-bit offset) into the specific format required by the current operating mode when FNSTENV 
and FNSAVE are executed. This simultaneity and context-dependent conversion is one way to 
provide a precise model the behavior of the X86 while preserving the information in a form more 

25 convenient for the native Tapestry machine as well. 

Whether the instruction is converted or emulated, at the end of the instruction (an end-of- 
recipe marker 926 reaches W-stage 150, or near the end of the emulation routine), the 
information is converted from the Tapestry internal format to the X86-defined format. In the 
converter case, FP-IP/OP/DP logic 993 responds to the end-of-recipe 926 by examining the 

30 exception state accumulated over all native instructions of the recipe. The data from sticky 
registers 994 are written to the X86 architected FP-IP, FP-OP and FP-DP registers., under the 
X86 mode in effect at the time of the instruction. Because the X86 definition of the FP-IP, FP- 
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OP and FP-DP information is somewhat context-dependent, the Tapestry conversion from 
intemal form to X86 form is context-dependent as well. All of the architecturally-visible side- 
effects from the X86 FP instruction are committed simultaneously, including FP-IP, FP-OP, and 
possibly FP-DP. Sticky registers 994 are then cleared. If no exception was raised, then the data 
5 result is written to the appropriate result register(s) (one or two of registers R32-R47, see Table 

1). 

There is a shadow state for FP-IP/OP/DP that is left undisturbed during handling of 
native exceptions within a sequence, if the sequence will complete normally and will require 
committing new FP-IP/OP/DP state. In practice this is not difficuh since the X86 process is 

10 virtualized only at instruction boundaries. FP-IP/OP/DP are preserved as long as the converter 
is off In one embodiment, shadow registers 994 are not architecturally addressable in the X86. 
In this embodiment, it is desirable that the X86 process not be context-switched until an X86 
instruction boundary, so that the information in the shadow registers 994 is not lost. In another 
embodiment, shadow registers 994 are addressable, so that they can be saved and restored on a 

15 context switch. 

3. STIS (store into instruction stream) flush boundary to next 
instruction 

The X86 allows "self-modifying code," also known as "store into instruction stream" 
20 (STIS), the case where an instruction stores a value in a location in memory that is later 

executed. In particular, the X86 allows an instruction (referred to instruction f) to modify the 
immediately-next-following instruction in memory (referred to instruction /+1). The X86 
architecture requires that the fetch and execution of the memory copy of instruction z+l reflect 
the modification induced by instruction /, even if the old contents of the memory location for 
25 instruction i+1 have already flowed most of the way down pipeline 120. Instruction i may be a 
simple store instruction, or a complex instruction. A complex instruction / may perform further 
work after the modification itself occurs. Thus, on each store to memory, the pipeline is 
examined for an STIS condition. The examination extends from the end of the current 
instruction back to the top of the pipeline, and continues back to I-cache 112, far enough to 
30 ensure that the write to memory has propagated throughout the memory system. When an STIS 
condition is detected, the pipeline and the appropriate portion of I-cache 112 are flushed. 
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Referring again to Fig. 9a, STIS detector 995 in E-stage 148, receives as its input the 
memory address of any store operation. STIS detector 995 compares the store address to all of 
the PC values 925 in pipeline 120, 134 for all younger instructions, that is, any younger 
instructions in E-stage 148, and all instructions in M-stage 146, A-stage 144, fetch stage 110, and 

5 I-cache 112. When a STIS condition is detected, the current X86 instruction is allowed to 
complete. Once the current instruction is complete, pipeline 120 is flushed from the next 
instruction back to fetch stage 110 at the beginning of the pipeline. In another embodiment, the 
flush only takes place from the matching instruction back - if there are instructions intervening 
between the instruction that generates the store and the modified instruction, those intervening 

10 instructions are allowed to complete. Note that the STIS detection and pipeline flushing is 
performed on the basis of X86 instructions. 

Data stores affect the data cache in the conventional manner, and also may invalidate I- 
cache 112. When the instruction fetch is restarted, I-cache 112 will miss, and the instruction 
fetch will reach all the way back to main memory. In one embodiment, a common I-cache 112 

15 caches both X86 instructions and the Tapestry native instructions, so that a single cache 

invalidation policy is effective to handle STIS conditions. In another embodiment, there is a 
separate D-cache, X86 I-cache, and Tapestry I-cache, and a store into the D-cache forces an 
invalidate of any copy in both of the I-caches. 

Note that the store operation may be in one instruction set, and the destination may be an 

20 instruction coded in the other instruction set. STIS detector 995 is cognizant of the unified memory 
address space for instructions of both instmction sets (see, for instance, the discussion of section VIII). 
There's a point of the pipeline at which it's guaranteed that the store will be present in I-cache 
112 early enough that the fetch will get the modified data, so no further consistency checks are 
required. If the store happens in between the time that instruction /+1 is fetched and the 

25 modification actually appears in I-cache 112, then STIS detector 995 flushes the pipeline, 
refetches the modified instruction out of I-cache 112 or wherever it resides in the memory 
system, and execution of the modified instruction begins anew. The unified address space for 
both instruction sets allows STIS detector 995 to compare the addresses without regard for the 
instruction set currently being executed, without special modification to support cross- 

30 instruction-set stores. 
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D. An externally-exposed RISC ISA as microinstruction set - implementing a 
second instruction set conversion and implementation with a user-accessible 
first instruction set 

1. External microcode 

5 It should be noted that a handful of features are only available though conversion of X86 

code, and are not available to native assembly language programmers. 

Much of the side-band 920 is only meaningful in X86 mode. For instance, the concepts 

of X86 instruction boundary information 926 and "interruptible point" information 990 are not 

meaningful in native execution mode. 
10 The immediate field in native external instructions is either six or twelve bits wide. 

Thirty-two bit immediates and branch displacements in internal formatted instructions are only 

available through X86 converter 136. 

A single X86 instruction may specify four components of a memory reference - a 

segment base, an offset of up to thirty-two bits coded as an immediate, a base register, and an 
1 5 index register (which may be scaled by two, four, or eight). A native Tapestry instruction can 

specify three components - either a segment base plus two registers, or a segment base plus a 

register plus a six-bit immediate. Converter 136 can generate a four-component address during 

X86 mode. 

20 2. Miscellaneous features 

There are a number of features of the external Tapestry native instruction set, as exposed 

to assembly-language programmers, that exist primarily to support an X86 microengine. 

Referring again to Fig. 9c, the native Tapestry LDA and STA instructions offer 
segmentation features that are a superset of X86 segmentation. Tapestry page tables and paging 
25 behavior is a superset of the paging features offered by the X86. Thus, these native Tapestry 

memory reference instructions perform all of the individual pieces of an X86 memory reference. 

The LDA and STA instructions offer a proxy mechanism: a reference can either obey 
X86 instruction semantics, or may obey less-restrictive native semantics. This feature is 
controlled by Tapestry extension bits in the segment descriptors. 
30 Tapestry includes integer and floating-point flags (condition codes) that mirror the 

behavior of the X86 EFLAGS. 

Some Tapestry arithmetic instructions have a bit that determines whether or not the 
integer flags are modified. Thus, in a multi-instruction recipe, the one Tapestry instruction that 
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computes the individual result on which the X86 flags are based will set the integer flags, and the 
other instructions in the recipe will leave the flags unmodified. 

Tapestry offers several instructions that are not commonly found in RISC architectures, 
in order to provide efficient implementation of the equivalent X86 instruction. These include 
5 byte swap instructions, certain shift and rotate instructions, etc. 

E. Restartable complex instructions 

1. Atomic MOV/POP stack segment pair via native single-step 

Recall fi-om the brief overview of the X86 segmentation scheme, introduced in section 

10 IX.A.6, that in the X86, all memory references are based off a segment descriptor and an offset 
into the segment. Thus, when an X86 program changes its stack, both the stack segment 
descriptor (SS) and the offset may need to be changed. If an interrupt arose at the boundary 
between the instruction that modifies SS and the instruction that loads the stack offset into the 
stack pointer register, the exception frame could not be pushed onto the memory stack, because 

15 of the inconstancy between the two portions of machine state that together define the top of 
stack. In order to prevent an interrupt firom corrupting the stack at such a boundary, the X86 
architecture defines that exceptions are inhibited in the boundary between a move or pop into SS 
and the following instruction. 

In the Tapestry implementation, a move or pop into SS is executed in emulator 316. 

20 Emulator 316 records in memory (a) the fact that single-step mode has been entered because of a 
modification of SS, (b) the interrupt flag that was in effect before the move or pop instruction, 
and (c) the current state of X86 single-stepping. Emulator 316 then writes the new value into SS. 
At the end of emulating the move or pop instruction, hardware interrupts are disabled as 
specified by the X86 architecture definition, and the processor is put into single-step mode. 

25 Hardware interrupts and instruction breakpoints are inhibited. Any X86 single-step exception 
that would otherwise have been signaled between the two instructions is suppressed, as well as 
an instruction breakpoint on the following instruction. Thus, interrupts or exceptions are 
suppressed in the boundary between the modification of SS and the following instruction. An 
RFE instruction returns execution to the converter. The converter executes the next instruction, 

30 which will usually be the instruction that sets the stack pointer register. At the end of the next 
instruction, a single-step exception vectors control into emulator 316. The single-step handler 
observes that the exception was raised because of a modification to SS, and in response, the 
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single-step handler restores hardware interrupts and the prior state of single-step mode. 
Execution is resumed in the converter, in the execution mode that prevailed before the initial 
modification to SS. 

2. IF bit change inhibition via native single-step 

The X86 architecture defines an interrupt flag. When it is asserted, maskable interrupts 
are allowed to intervene between instructions, generating an asynchronous exception. When the 
interrupt flag is deasserted, then maskable hardware interrupts are ignored. The X86 STI 
instruction sets the interrupt flag; the CLI instruction clears the interrupt flag, inhibiting 
interrupts. A POP into the EFLAGS register also changes the interrupt flag, because the 
interrupt flag is one of the EFLAGS bits. 

The X86 architecture defines the STI instruction as maintaining interrupts disabled in the 
immediately following instruction boundary, and as enabUng interrupts following the completion 
of execution of the next instruction following. This definition is typically exploited at the end of 
a routine: the routine ends with an STI instruction and then a RET instruction, so that interrupts 
will remain disabled until the completion of the return instruction. Interrupts are only re-enabled 
after execution resumes in the calling context. 

In the Tapestry implementation, the STI and CLI instructions are executed in emulator 
316. At tiie end of the emulation routine for STI, hardware interrupts are disabled, any 
instruction breakpoint for the following instruction is inhibited, the current state of X86 single- 
step mode is saved, X86 single-step mode is enabled, and a record is set in the emulator's private 
memory to indicate that the next X86 single-step exception is to be handled in a special handler. 
Emulator 316 RFE's back to the converter. The next X86 instruction is executed. At the end of 
the next X86 instruction, the end-of-recipe X86_COMPLETED side-band bit 926 triggers a 
single-step exception. The single-step handler examines tiie record in private memory, and finds 
that the single-step exception was caused by an STI insti^ction. The handler enables hardware 
interrupts (unless the next instinction was a CLI), and restores X86 single-step to its previous 
state. Emulator 316 RFE's back to the converter, and execution resumes. 

In the case of an STI followed immediately by a second STI instruction, the special 
behavior is only applied to the fu-st STI. An interrupt would be allowed to intervene after the 
second STI instruction, in agreement with the X86 architectural definition. 
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F. The FWAIT instruction 

The Tapestry FWAIT instruction comes in two forms. One form follows the X86 
FWAIT instruction^ simply allowing the floating-point pipeline to drain. 

The second form, FWAIT.cc, performs the drain, and also enables the setting of arbitrary 
5 state in four X86 floating-point status word bits. The Tapestry FWAIT instruction has two four- 
bit immediate operands. If bit i of the first immediate operand is One, then bit / of the floating- 
point condition code is set to bit / of the second immediate operand, for / between 0 and 3. Thus, 
of any bit / that is Zero in the first immediate operand, the floating-point condition code is 
unchanged. 

10 FWAIT.sync operates as follows. If one or more of the accrued exception flags in the 

floating-point status word are One and if the corresponding mask bits in the floating-point 
control word are Zero, the instruction faults and invokes VECT_FP_EXCEPTION. Thus, a 
floating-point exception is raised if any accrued exception flag in the floating-point status word 
is not masked by the floating-point control word. 

15 Thus, the Tapestry FWAIT instruction is defined to allow separate control of a number of 

functions that are inseparably bundled in the X86 FWAIT instructions. 

The FWAIT.cc instruction is useful in the context of certain X86 floating-point load or 
store operations that set the floating-point control word. In the Tapestry machine, the floating- 
point control word is in the floating-point unit, and the memory unit is relatively distinct. The 

20 converter issues a load or store instruction to the memory unit, and issues an FWAIT.cc to the 
floating-point unit. This implements both side-effects of the X86 instruction, even though those 
side effects are in different functional units. 

The FWAIT.cc instruction may be used to implement the X86 FXAM instruction. As 
part of decoding the FXAM instruction, converter 136 determines whether the floating-point top 

25 of stack is empty (recall that the mapping from the X86 floating-point stack to the real Tapestry 
registers is performed in the converter 136). If the top of stack is empty, then converter 136 
generates an FWAIT.cc to write a fixed bit pattern, defined by the X86 architecture, into the 
floating-point condition codes. 



30 X. Interrupt priority 

The TAXi system uses five exceptions, and one software trap. DMU 700 introduces one 

new interrupt sub-case. These interrupts are summarized in the following Table 11. The fourth 
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column of Table 1 1 gives the relative interrupt priority. The fifth column indicates the section of 
this specification in which the respective interrupts are discussed. 



Table 11 


name 


description 


type 


priority 


discussion 


VECT_TAXi_UNPROTECTED 


starting profile on a 
TAXi unprotected page 


note 1 


4.0 


1.F 


VECT_TAXi_PROBE 


probe for translated code 
exception 


note 2 


4.1 


VI 


VECT_TAXi_PROFILE 


profile packet complete 
exception 


note 2 


4.2 


V 


VECT_TAXi_PROTECTED 


writing to a TAXi 
protected page 


fault 


5.4 


I.F 


VECT_TAXiJO 


read from (ASI # 0) in 
translated code 


fault 


5.5 


VIII.A 


VECT_TAXi_EXIT 


restart converter on 
TAXi code completion 


software 
trap 


2.4 


VI.F 


DMUJNVALIDATE 


DMU invalidation event 


interrupt 


2.0 


VII 


note 1 . This fault is raised on the 1 
note 2. This fault is raised as a tra] 
completes writing its data to f 


first native instruction in an X86 converter recipe. 
3 on the TAXi instruction, i.e. the TAXi instruction 
be GPR. 



5 To achieve performance, TAXi code does not keep X86 state in the canonical locations 

assumed by converter 136 and emulator 316. Therefore, when TAXi code is interrupted, the 
converter is not allowed to resume without first recovering the canonical picture of the X86 
machine's state. 

The exception strategy described supra is intended to achieve correctness through 
10 simplicity, to have a single common strategy for processing all exceptions, to ensure that 

exceptions raised in TAXi code are processed by exactly the same code as exceptions raised by 
the converter, to maximize performance, to delay abandoning TAXi code until it is known that 
an exception must be surfaced to the X86, and to allow TAXi code to forego maintaining the 
X86 FP exception state. 

15 

For the convenience of the reader, this description has focused on a representative sample 
of all possible embodiments, a sample that teaches the principles of the invention and conveys 
the best mode contemplated for carrying it out. The description has not attempted to 
exhaustively enumerate all possible variations. Further undescribed alternative embodiments are 
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possible. It will be appreciated that many of those undescribed embodiments are within the 

literal scope of the following claims, and others are equivalent. 

The following volumes are incorporated by reference. INTEL Architecture Software 

Developer's Manual, vol. 1-3, Intel Corp. (1997); Gerry Kane, PA-RISC 2.0 
5 Architecture, Hewlett-Packard Professional Books, Prentice-Hall (1996); Richard L. Sites 

and Richard T. Witek, The Alpha AXP Architecture Reference Manual, 2d ed., Digital 

Press, Boston (1995); David A. Patterson and John L. Hennessey, Computer 

Architecture: A Quantitative Approach, Morgan Kaufman Publ., San Mateo, CA (1990); 

Timothy Leonard, ed., VAX Architecture Reference Manual, Digital Equipment Corp. 
1 0 (1 987); Peter M. Kogge, The Architecture of Pipelined Computers, Hemisphere Publ., 

McGraw Hill (1981); John Mick and James Brick, Bit-Slice Microprocessor Design, 

McGraw-Hill (1980). 

REFERENCE TO MICROFICHE APPENDIX 

15 An appendix of 28 frames recorded on microfiche, which can be found in the file of 

United States application Serial No. 09/239,194, filed January 28, 1999, is incorporated herein 
by reference. 

A portion of the disclosure of this patent document contains material that is protected by 
copyright. The copyright owner has no objection to the facsimile reproduction of the patent 
20 document or the patent disclosure as it appears in the Patent and Trademark Office file or 
records, but otherwise reserves all copyright rights whatsoever. 

We claim: 
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CLAIMS 



1 . A method, comprising the steps of: 

concurrently executing on a single computer a first operating system coded in a RISC 
instruction set, being an instruction set having a fixed-length instruction format and a 
load/store/operate organization, and a second operating system coded in a CISC instruction set, 
being an instruction set with variable-length instructions and many instructions having multiple 
side-effects, the CISC operating system being unmodified for execution on the computer of the 
RISC instruction set; and 

accepting an exception raised while executing a program coded in the RISC instruction 
set, and in response, initiating an execution thread under the CISC operating system; 

delivering the exception to the initiated thread for handling by the CISC operating 

system. 

2. A method, comprising the steps of: 

concurrently executing on a single computer a first operating system coded in a RISC 
instruction set, being an instruction set having a fixed-length instruction format and a 
load/store/operate organization, and a second operating system coded in a CISC instruction set, 
being an instruction set with variable-length instructions and many instructions having multiple 
side-effects, the CISC operating system being unmodified for execution on the computer of the 
RISC instruction set; and 

accepting an exception occurring during execution of a program coded in the RISC 
instruction set, and routing the exception for handling in the CISC operating system. 

3. The method of claim 2, further comprising the step of: 

accepting an exception occurring during execution of a program coded in the CISC 
instruction set, and routing the exception for handling in the RISC operating system. 

4. The method of claim 3, wherein the RISC operating system comprises a 
collection of interrupt service routines programmed to emulate instructions in the CISC 
instruction set. 
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5. The method of claim 3, wherein: 

the computer has a file of general registers, the CISC instruction set providing 
accessibility to only a subset of the general register file, intermediate results of instructions of the 
CISC instruction set being stored in registers of the general register file that are inaccessible in 
the CISC instruction set. 

6. The method of claim 3, wherein: 

during execution of an instruction on the computer, in response to an operation of the 
instruction calling for an architecturally-visible side-effect in an architecturally-visible storage 
location, storing a value representative of an architecturally-visible representation of the side- 
effect, a format of the representative value being different than an architecturally-visible 
representation of the side-effect, and resuming the execution without generating the 
architecturally-visible side-effect; 

later writing the architecturally-visible representation corresponding to the representative 
value into the architecturally-visible storage location. 

7. The method of claim 3, further comprising the steps of: 

recognizing a condition that is a superset of a condition being monitored for occurrence, 
and raising a first exception as a result of recognizing the superset condition; 

in software, filtering the superset condition to determine whether the monitored condition 
has occurred; 

if the monitored condition has occurred, establishing a second exception to be raised after 
execution of further instructions of the instruction stream. 

8. The method of claim 3, further comprising the step of: 

recognizing a condition in which a first CISC instruction is to affect the execution of a 
second CISC instruction, and in response, setting the processor into single-step mode; 

taking a single-step exception after executing the second CISC instruction, and setting the 
processor out of single-step mode. 



Atty. Docket No. 30585/28 

NYDOCS04/ 285781 



201 



Express Mail Label EI465234796US 



9. The method of claim 3, further comprising the steps of: 

delaying accepting exception occurring at an intermediate point of execution of a CISC 
instruction until an CISC instruction boundary. 

10. The method of claim 3, further comprising the step of: 

in an exception handler coded in the RISC instruction set, saving a portion of the context 
of the computer, and altering the context of the excepted program before delivering the exception 
to the CISC operating system. 

1 1 . The method of claim 2, further comprising the step of:: 

without modifying the CISC operating system, establishing an entry handler for 
execution at a specified entry point or on a specified entry condition to the CISC operating 
system, the entry handler programmed to save a context of an excepted program and modify the 
program context before delivering the modified context to the CISC operating system. 

12. The method of claim 2, wherein: 

the RISC instructions and CISC instructions are executed in a common execution 
pipeline. 

1 3 . The method of claim 2, wherein: 

while executing a program coded in the RISC instruction set, receiving an exception; 
in response to the exception, initiating an execution thread in the CISC operating system; 
delivering the exception to the initiated thread for handling by the CISC operating 

system, 

14. The method of claim 2, wherein: 

executing an instruction coded in the RISC instruction set, the instruction storing into a 
memory location a value of an instruction coded in the CISC instruction set; 

in response to the storing, marking as stale copies of the memory location, including 
copies in any instruction cache; 

executing the CISC instruction in the execution pipeline. 
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15. The method of claim 2, further comprising the step of: 

in the RISC operating system, building an exception frame on a memory stack before 
tending execution to the CISC operating system. 

16. The method of claim 2, wherein: 

the exception is a synchronous fault generated by a RISC instruction. 

17. The method of claim 2, wherein: 

the exception is a trap requesting a file access service from the CISC operating system on 
behalf of the program. 

18. A computer, comprising: 

a first operating system loaded into memory, being coded in a RISC instruction set, being 
an instruction set having a fixed-length instruction format and a load/store/operate organization; 
and 

a second operating system loaded into memory, being coded in a CISC instruction set, 
being an instruction set with variable-length instructions and many instructions having multiple 
side-effects, the CISC operating system being unmodified for execution on the computer of the 
RISC instruction set; and 

hardware and/or software designed to accept an exception occurring during execution of 
a program coded in the RISC instruction set, and to route the exception for handling in the CISC 
operating system. 

19. The computer of claim 1 8, further comprising: 

hardware and/or software designed to accept an exception occurring during execution of 
a program coded in the CISC instruction set, and to route the exception for handling in the RISC 
operating system. 

20. The computer of claim 19, further comprising: 
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an instruction decoder for the CISC instruction set designed to issue, for at least some of 
the decoded CISC instructions, two or more instructions in the RISC instruction set into the 
execution pipehne. 

21 . The computer of claim 20, further comprising: 

pipeUne exception circuitry, effective on recognizing an exception occurring in a program 
coded in the CISC instruction set, to architecturally expose in processor registers of the computer 
information describing a processor state of the computer, and to transfer execution to an 
exception handler; and 

pipeline resumption circuitry effective after completion of the software exception handler 
to resume execution of the excepted program based on the information in the processor registers; 

the processor registers and general purpose registers of the computer architecturally 
exposing sufficient processor state and providing sufficient working storage for execution of the 
exception handler and resumption of the program, without storing processor state to the main 
memory. 

22. The computer of claim 20, fiirther comprising: 

a register and control logic for that register that capture and architecturally expose an 
intra-instruction program counter value when an instruction of the CISC instruction set raises an 
exception at an intermediate point. 

23. The computer of claim 19, wherein: 

the RISC instructions and CISC instructions are executed in a common execution 
pipeline. 

24. The computer of claim 19, wherein: 

at least a portion of the implementation of the CISC instruction set includes emulation 
routines coded in the RISC instruction set. 

25. The computer of claim 19, fiirther comprising: 
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processor register control circuitry designed to store information describing the decoding 
of the CISC instructions into architecturally-visible processor registers of the computer. 

26. The computer of claim 1 9, further comprising: 

pipeline control circuitry designed to recognize an exception occurring in a CISC 
instruction after a first side-effect of the CISC instruction has been architecturally committed, to 
transfer control to a software exception handler for the first exception, and to resume execution 
of the excepted CISC instruction after completion of the exception handler, processor registers of 
the computer being designed to capture sufficient information about the state of the excepted 
instruction that the transfer and resume are effected without saving intermediate results of the 
excepted CISC instruction on a memory stack. 

27. The computer of claim 19, fiirther comprising: 
a multi-stage execution pipeline; and 

an instruction decoder designed to generate information descriptive of instructions to be 
executed by the pipeline, and to store the information into a non-pipelined register of the 
computer; 

the instruction decoder being designed to determine whether instructions will complete in 
the pipeline, and to abstain fi*om writing descriptive information into the register for instructions 
following an instruction determined not to complete. 

28. The computer of claim 19, wherein a class of exceptions is handled in part in each 
of the CISC and RISC operating systems. 

29. The computer of claim 1 8, fiirther comprising: 

store monitoring circuitry designed to monitor store instructions executed by the 
computer and to invalidate any copies of a datum in memory overwritten by the store 
instructions, including copies of instructions in any instruction cache in the instruction set other 
than the instruction set of the current store instruction. 
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30. The computer of claim 1 8, further comprising a memory management unit 
designed to manage the storage of instructions of the RISC and CISC instruction sets between a 
main memory of the computer and one or more cache levels. 

31. A method, comprising the steps of: 

in response to an exception raised while executing a program coded in instructions of a 
first instruction set architecture, initiating an execution thread under an operating system coded 
in instructions of a second instruction set architecture; 

delivering the exception to the initiated thread for handling by the operating system. 

32. The method of claim 3 1 , further comprising: 

executing a program in a computer comprising a hardware instruction decoder 
implementing less than an entire architectural definition of the first instruction set, a remainder 
of the first instruction set being implemented in a software emulator. 

33 . The method of claim 3 1 : 

wherein the first instruction set is a complex instruction set having variable-length 
instructions and many instructions having multiple side-effects; 

and further comprising the step of storing information describing the decoding of the 
complex instructions into architecturally-visible processor registers of the computer. 

34. The method of claim 3 1 , further comprising the steps of: 

during execution of an instruction on the computer, in response to an operation of the 
instruction calling for an architecturally- visible side-effect in an architecturally-visible storage 
location, storing a value representative of an architecturally-visible representation of the side- 
effect, a format of the representative value being different than an architecturally-visible 
representation of the side-effect, and resuming the execution without generating the 
architecturally-visible side-effect; 

later writing the architecturally- visible representation corresponding to the representative 
value into the architecturally- visible storage location. 
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35. The method of claim 3 1 , further comprising the step of: 

in an exception handler coded in the first instruction set, saving a portion of the context 
of the computer, and altering the context of the excepted program before delivering the exception 
to the operating system. 

36. The method of claim 3 1 , further comprising the step of: : 

without modifying the CISC operating system, establishing an entry handler for 
execution at a specified entry point or on a specified entry condition to the CISC operating 
system, the entry handler programmed to save a context of an excepted program and modify the 
program context before delivering the modified context to the CISC operating system. 

37. The method of claim 3 1 , wherein: 

the first instruction set and second instruction set are executed in a common execution 
pipeline. 

38. A computer, comprising : 

hardware and/or software designed to respond an exception raised while executing a 
program coded in instructions of a first instruction set architecture of the computer by initiating 
an execution thread under an operating system coded in instructions of a second instruction set 
architecture and running on the computer; 

hardware and/or software designed to deliver the exception to the initiated thread for 
handling by the operating system. 

39. The computer of claim 38, further comprising: 

pipeline exception circuitry, effective on recognizing an exception occurring in the 
program, to architecturally expose in processor registers of the computer information describing 
a processor state of the computer, and to transfer execution to an exception handler; and 

pipeline resumption circuitry effective after completion of the software exception handler 
to resume execution of the program based on the information in the processor registers; 

the processor registers and general purpose registers of the computer architecturally 
exposing sufficient processor state and providing sufficient working storage for execution of the 
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exception handler and resumption of the program, without storing processor state to the main 
memory. 

40. The computer of claim 38, wherein: 

the first instruction set is a RISC instruction set, being an instruction set having a fixed- 
length instruction format and a load/store/operate organization; and 

the second instruction set is a CISC instruction set, being an instruction set with variable- 
length instructions and many instructions having multiple side-effects. 

41 . The computer of claim 39, wherein: 

the RISC instructions and CISC instructions are executed in a common execution 
pipeline. 

42. The computer of claim 39, further comprising: 

pipeline control circuitry designed to recognize an exception occurring in a CISC 
instruction after a first side-effect of the CISC instruction has been architecturally committed, to 
transfer control to a software exception handler for the first exception, and to resume execution 
of the excepted CISC instruction after completion of the exception handler, processor registers of 
the computer being designed to capture sufficient information about the state of the excepted 
instruction that the transfer and resume are effected without saving intermediate results of the 
excepted CISC instruction on a memory stack. 

43. The computer of claim 39, wherein a class of exceptions is handled in part in each 
of the CISC and RISC operating systems. 
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COMPUTER WITH TWO OPERATING SYSTEMS 
ABSTRACT 

A computer concurrently executes a first operating system coded in a RISC instruction 
set and a second operating system coded in a CISC instraction set. When an exception is raised 
while executing a program coded in the RISC instruction set, an execution thread may be 
initiated under the CISC operating system. The exception may be delivered to the initiated 
thread for handling by the CISC operating system. 
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320 

X86-to Tapestry transition exception handler ^ 

//This handler is entered under the following conditions: 
// 1. An x86 caller \m\&% a native function 
// 2. An x86 function returns to a native caller 
// 3. x86 software returns to or resumes an interrupted native function following 
// an external asynchronous interrupt, a processor exception, or a context switch 
^321 

dispatch on the two least-significant bits of the destination address { 
case"00" // calling a native subprogram 

// copy Iinl(age and stacl< frame infomiation and call parameters from the memory 
// stacl( to the analogous Tapestry registers 
LR -^[SP++] // set up linl(age register-^"^^^ . 
AP -^SP // address of first argument-^'^'^^ 325 

SP-*-SP-8 //allocate return transfer argument area 327 
SP -»-SP & (-32) // round the stack pointer down to a 0 mod 32 boundary ^ 
XD-^ 0 // inform callee that caller uses X86 calling conventions ^ 328 

case "01" // resuming an X86 thread suspended during execution of a native routine >j 
ifthe redundant copies of the save slot number in EAX and EDXdo not match orif \ 
the redundant copies of the timestamp in EBXfCX and ESIfDI do not match {J 
// some form of bug or thread corruption has been detected 
goto TAPESTRY_CRASH_SYSTEM( thread-corruption-error-code ) 372 

save the EBX:ECX timestamp in a 64-bit exception handler temporary register! 

(this will not be overwritten during restoration of the full native context) j 
use save slot number in EAX to locate actual save slot storage-^374 
restore full entire native context (includes new values for all x86 registers) -\_„yc 
if save slot's timestamp does not match the saved timestamp { "^376 
// save slot has been reallocated; save slot exhaustion has been detected 
goto TAPESTRY_CRASH_SYSTEM( save-slot-ovenwritten-error-code )x 077 

free the save slot ^^^^ 

case"10" // returning from X86 callee to native caller, result already in registers 
RV0<63:32> -^edx<31:00> // in case result is 64 bits — —333 
convert the FP top-of-stack value from 80 bit X86 form to 64-bit form in RVDP 004 
SP —ESI // restore SP from time of call ^337 

case"11" // returning from X86 callee to native caller, load large result from memory 
RV0..RV3 ^ load 32 bytes from [ESI-32] // (guaranteed naturally aligned) ^-s^oof, 
SP— ESI // restore SP from time of call ■V337 

EPC— EPC & 4 // reset the two low-order bits to zero^ ooe 

pre ^336 

•^^^^338 
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340 

/ 

Tapestry-to-X86 transition exception liandler 

// This handler is entered under the following conditions: 
//la native caller invokes an x86 function 
// 2. a native function returns to an x86 caller 
switch on XD<3:0>{ 

XD_RET_FP: // result type is floating point 

FO/FI -^FINFLATE.de( RVDP) // X86 FP results are 80 bits 
SP-^ from RXA save // discard RXA, pad, args 

FPCW-*-image after FINIT & push // FP staci( has 1 entry 
gotoEXiT 

XD_RET_WRITEBACK: // store result to @RVA, leave RVA in eax 

RVA-*-from RXA save // address of result area 
copy decode(XD<8:4>) bytes from RV0..RV3 to [RVA] y 342 

eax-^ RVA // X86 expects RVA in eax 

SP-^from RXA save // discard RXA, pad, args 

FPCW^image after FINIT // FP stack is empty 

goto EXIT 

XD_RET_SCALAR: // result in eaxieda 

edx<31 :00> eax<63:32> // in case result is 64 bits 
SP-^from RXA save // discard RXA, pad, args 

FPCW^image after FINIT // FP stack is empty 

goto EXIT 

XD_CALL_HIDDEN_TEMP: // allocate 32 byte aligned hidden temp 
esi-*-SP // stack cut back on return 

SP-^ SP - 32 // allocate max size temp 1 344 

RVA-*-SP //RVA consumed later by RR J 

LR<1:0>-^"11" //flag address for return & reload^ 

gotoCALLCOIVlMON 345 

default: // remaining XD_CALL_xxx encodings 

esi^SP // stack cut back on retum ^ 

LR<1:0>-^"10" //flag address for return-. 343 

CALLCOMMON: 347 346 

interpret XD to push and/or reposition args 
[-SP]-^ LR // push LR as retum address 

EXIT: I- 348 

setup emulator context and profiling ring buffer pointer 

1 ^349 

RFE-^ //to original target 

} 

FIG. 31 



350 
/ 

interrupt/exception handler of Tapestry operating system: ^ 
II Control vectors here when a synchronous exception or asynchronous interrupt is to be 
// exported to / manifested in an x86 machine. 

//The interrupt is directed to something within the virtual X86, and thus there is a possibility 
// that the X86 operating system will context switch. So we need to distinguish two cases: 
// either the running process has only X86 state that is relevant to save, or 
// there is extended state that must be saved and associated with the current machine context 
// (e.g., extended state in a Tapestry library call in behalf of a process managed by X86 OS) 
if execution was Interrupted in the converter - EPC.ISA == X86 { ] 
// no dependence on extended/native state possible, hence no need to save any ?-351 
goto EM86_Deliver_lnterrupt( intenrupt-byte ) J 
}eIseifEPC.Taxi_Active{ ^ 
Ilk Taxi translated version of some X86 code was running. Taxi will rollback to an 
//x86 instruction boundary. Then, if the rollback was induced by an asynchronous external 
// interrupt, Taxi will deliver the appropriate x86 interrupt. Else, the rollback was induced I „co 
// by a synchronous event so Taxi will resume execution in the converter, retriggering the ' 
// exception but this time with EPC.ISA == X86 
goto TAXi_Rollback( asynchronous-flag, interrupt-byte ) 
}eIseifEPC.EM86{ 

// The emulator has been interrupted. The emulator is coded to allow for such 
// conditions and permits re-entry during long running routines (e.g. far call through a gate) y 354 
//to deliver extemal interrupts 
goto EM86_DeliverJnterrupt( interrupt-byte ) 



}else{ 



//This is the most difficult case - the machine was executing native Tapestry code on 
// behalf of an X86 thread. The X86 operating system may context switch. We must save 
// all native state and be able to locate it again when the x86 thread is resumed. 
^361 

allocate a free save slot; if unavailable free the save slot with oldest timestamp and try again 
save the entire native state (both the X86 and the extended state) 1 oeo 
save the X86 EIP in the save slot J ^353 

overwrite the two low-order bits of EPC with "01" (will become X86 interrupt EIP) ^ 
store the 64-bit timestamp in the save slot, in the X86 EBX:ECX register pair (and, "1 „p . 

for further security, store a redundant copy in the X86 ESI:EDI register pair) j 
store the a number of the allocated save slot in the X86 EAX register (and, again for \ 

further security, store a redundant copy in the X86 EDX register) J^^^ 
goto EM86_Deliver_lnterrupt( interrupt-byte ) 



>360 
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typedef struct { ^ 

save_slot_t * newer, // pointer to next-most-recently-allocated save slof\ 

save_slot_t* older; //pointer to next-older save slot j379c 

unsigned int64 epc; //saved exception PC/IP ^ 

unsigned int64 pew; // saved exception PCW (program control word) i 

unsigned int64 registers[63]; // save the 63 writeable general registers 

// other words of Tapestry context J 

timestampj timestamp; // timestamp to detect buffer ovemin ■>> 

int save_slotJD; //ID number of the save slot 358 

boolean save_slotJs_full; //full /empty flag 357 

}save_sIot_t; ^359 J 

save_slot_t * save_slot_head; // pointer to the head of the queue -y 

save_slot_t* save_siot_tail; //pointer to the tail of the queue ^ 379a 

^379b 
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DESCRIPTION OF SIDE-BAND INFORMATION 


INSTRUCTIONS WITH 
Imnie FIELD 




THE CONVERTER MAY SUPPLYAFULL32-BITIMMEDIATE. 


BRANCHES WITH 
DISPIACEMENT 




THE CONVERTER MAY SUPPLYAFULL32-BIT DISPLACEMENT 


LDA/STA 


INTEGER 


AFULL 32-BITDISPlACEMENTIS SENT ON THE IMMEDIATE BUS; THIS ISADDED TO 
SRC1T0C0MPUTE THE OFFSETFOR SOME ADDRESSING MODES. 


CJcond 


INTEGER 


THE CONVERTER MAYSPECIFYA16 OR 32-BiTADDRESSSIZE IN PARALLEL WITH THIS 
INSTRUCTION (A32-B1T DISPIACEMENT MAYALSO BE PROVIDED). 


CJcond 


INTEGER 


THE CONVERTER MAYSPECIFYA160R 32-BITADDRESSSIZE IN PARALLEL WITH THIS 
INSTRUCTION. A32-BITDISPIACEMENT MAYALSO BE PROVIDED. 


FROMPR 


INTEGER 


3-BITS OFTOS (TOP-OF-STACK) ARE SENT ON THE IMMED^TE BUS IN PARALLELWITH 
THIS INSTRUCTION FOR USEBYTHEFNSTSW INSTRUCTION CONVERTER SEQUENCE. 


LEA 


INTEGER 


A6-BITINDEXRE6ISTERSPECIFIER,A32-BITDISPLACEMENT,ANDA2-BIT SCALE 
FACTORARE PASSED FROM THE CONVERTERASADDITIONALINPUTTOTHE HARDWARE IN 
ORDERTO FORM ACOMPLETEx86 ADDRESSING MODE. 


LDAI 


INTEGER 


A6-BITINDEXREGISTERSPECIFIER,A32-BITDISPLACEMENT.ANDA2-BIT SCALE 
FACTORARE PASSED FROM THE CONVERTER AS ADDITIONAL INPUT TO THE HARDWARE IN 
ORDERTO FORM ACOMPLETEx86 ADDRESSING MODE. ADDITIONALLY.ASECOND 
DESTINATION REGISTERIS PASSED ASTHE DESTINATION OFTHEADDRESS 
AUTOINCEMENTMODE. 
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A6-BIT INDEX REGISTERSPECIFIER,A32-BITDISPLACEMENT.ANDA2-BIT SCALE 
FACTORARE PASSED FROMTHECONVERTERASADDITIONALINPUTTO THE HARDWARE IN 
ORDERTOFORM ACOMPLETE x86 ADDRESSING MODE. ADDITIONALLY.ASECOND 
DESTINATION REGISTERIS PASSED AS THE DESTINATION OFTHEADDRESS 
AUTOINCREMENTMODE. 
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X86 instruction PUSHAD 
Temp := (ESP) 
Push(EAX) 
Push(ECX) 
PushlEDX) 
Push(EBX) 
Push(Temp) 
Push(EBP) 
Push(ESI) 
Push(EDI) 
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Native Instruction Recipe 
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tmpJ.ESP /* copy working SP to temp */ 
^EAX,SS,tmp_d^ 
ECX,SS,tmp_d ^953 
EDX,SS.tmp_d 
EBX,SS,tmp_d 
ESP,SS.tmp_d 
EBP,SS.tmp_d 
ESI.SS,tmp_d 
EDI,SS,tmp_d 

ESP.tmpJ /* commit new SP*/ 



IDIOM 


USAGE 


LOAD /OP [/STORE] 


LOAD DATA 


COMPLEX ADDRESS CALCULATION 


COMPUTED OFFSET 


MOV mem, [DEFGS]S / PUSH [DEFGSJS 
(SELECTOR PUSH/STORE) 


SELECTOR (PROCESSOR REGISTER NOT DIRECTLY 
ACCESSIBLE BY STORE INSTRUCTIONS) 


PUSHA (PUSH ALL) 


INTERMEDIATE STACK POINTER; COMMIT AT END 


POPA(POPALL) 


INTERMEDIATE STACK POINTER; COMMIT AT END 


MOV mem, Imm/PUSH Imm 


INTERMEDIATE (NOT AVAILABLE AS AN OPERAND TO 
STORE INSTRUCTION) 


MULTIPLY 


INTERMEDIARYTO CONNECT CONTIGUOUS NATIVE 
REGISTERPAIRTOX86 REGISTER PAIR 


DIVIDE 




XCHG 


THE CLASSIC USEOFATEMPORARY! 


POP mem 


STACK POINeUNTILMEMORYOPERATIONS ARE FINISHED 











FIG. 9F 



960 



961 



X86 instruction ADD r/m8,r8 
DEST:=DEST + SRC: 



962 
963 



964-^ 

FIG. 9G 



Native Instruction Recipe 
- LDA.b.write_intent tmp _d,Seg.Base,Base 
ADD.b tmp_d,tmp_d,reg 
STA.b tmp_d,Seg.Base,Base 



967 

X86insiructionCALLr/mX /* near absolute call */ 
IF target instruction pointer is not wittiin code segment limit 

THEN#GP(0);FI; L968 
IF slack not large enough for a 4-byte return address 

THEN#SS(0);FI; L969 
Push(EIP); 
EIP:=EIP + DEST; 



FIG. 9H 



976 



X86 instmction CALL re1X /* near IP-relative call */ 
IF target instruction pointer is not within code segment limit 

THEN#GP(0);FI; 
IF stack not large enough for a 4-byte return address 

THEN#SS(0);FI; 
Push(EIP); 
EIP:=E1P + DEST; 

FIG. 91 



7 



Native Instmction Recipe 
LOAD.Iimit_checkrO,CS:reg_d 

^971 
9J2 

STOREDEC.X IP.SS.ESP 
JR reg_d 

^973 



Native Instruction Recipe 



977 

STOREDEC.X IP.SS,ESP 
JR reg_d 

^978 



980 981 

/ / 

X86 instruction LOOP imm8 Native Instruction Recipe 
Count :=ECXi 

Count:=Count-1; DEC.X ECX.ECX 

IF (Count ==0) V 

THENBranchCond:=1; 982 

ELSEBranchCond: = 0; 

Fl; CJNE ECX,r0.imm8 



lF(BranchCond ==1) 
THEN 

NextEiP := NextElP + SignExtend(DEST); 

IF target instruction pointer is not with code segment limit 

THEN 

#GP{0); /* ECX not modified */ 
ELSE 
ECX := COUNT; 
EIP:= NextElP; 

FI; 
ELSE 
ECX := Count; 

Terminate loop and continue program execution at EIP; 
FI; 

FIG. 9J 



^983 



986 



987 



X86REPNZMOVS 
WHILE ECX;^0 
DO 

service pending inten^ipts (if any); 
execute associated MOV instruction; 
ECX:=ECX-1; 
IFECX=0 

THEN exit WHILE loop; 
IFZF = 1 

THEN exit WHILE loop; 

Fl; 
OD; 



988 



989 
991 



LDA.b 

STOREINC 

JNZ 

LDA.b 

STOREINC 



989^iISA.b 



989 



STOREINC 



tmp_d, src++ 
dest++,tmp_d 
predicted not taken 
tmpj, src++ 
dest++,tmp_d 
predicted not taken 
tmpJ, src++ 
dest++,tmp_d 
predicted not taken 



FIG. 9K 
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application in accordance with 37 C.F.R. § 1.56(a), and acknowledge the duty to disclose 
material information as defined in 37 C.F.R. § 1 .56(a) that occurred between the filing date(s) of 
our earlier filed U.S. parent application(s) listed below, and the filing date of this continuation- 
in-part application; 

I have reviewed and understand the contents of the above-identified specification, 
including the claims, as amended by any amendment referred to above. 

No applications for patents or inventor's certificates on common subject matter have been 
filed in any country foreign to the United States of America 

POWER OF ATTORNEY: I hereby appoint the following attorneys to prosecute this 
application and transact all business in the Patent and Trademark Office connected therewith: 

James R. Wamot, Jr., Reg. No. 34,455, David M. Klein, Reg. No. 35,221, 
David E. Boundy, Reg. No. 36,461, Donna Marie Werner, Reg. No. 36,719, 
Warren L. Nachlis, Reg. No. 41,216, Alex V. Chachkes, Reg. No. 41,663, 
Antoinette E. Baker, Reg. No. 44,018, and Anthony Meola, Reg. No. 44,936, 
all of Shearman & Sterling, 599 Lexington Avenue, New York, NY 10022, 
(212) 848-4000; and Sally J. Daub, Reg. No. 41,478, of A T I Technologies, 
Inc., 75 Tiverton Court, Unionville, Ont., L3R 9S3, Canada 99915, (905) 882- 
2671. 

Send correspondence to: 

Shearman & Sterling 
Intellectual Property Docketing 
599 Lexington Avenue 
New York, NY 10022 

Direct telephone calls to David E. Boundy, Esq. at telephone number (212) 848-7928. 

I hereby declare that all statements made herein of my own knowledge are true and that 
all statements made on information and belief are believed to be true; and fiirther that these 



Declaration and Power of Attorney 
NYDOCS04/ 285492 



1 



30585/28 EI465234796US 



statements were made with the knowledge that willful false statements and the like so made are 
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